• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            woaidongmao

            文章均收錄自他人博客,但不喜標(biāo)題前加-[轉(zhuǎn)貼],因其丑陋,見諒!~
            隨筆 - 1469, 文章 - 0, 評論 - 661, 引用 - 0
            數(shù)據(jù)加載中……

            JSON 入門指南

            級別: 初級

            雪峰, 撰稿人

            2008 8 22

            JSON JavaScript Object Natation,它是一種輕量級的數(shù)據(jù)交換格式,非常適合于服務(wù)器與 JavaScript 的交互。本文將快速講解 JSON 格式,并通過代碼示例演示如何分別在客戶端和服務(wù)器端進行 JSON 格式數(shù)據(jù)的處理。

            盡管有許多宣傳關(guān)于 XML 如何擁有跨平臺,跨語言的優(yōu)勢,然而,除非應(yīng)用于 Web Services,否則,在普通的 Web 應(yīng)用中,開發(fā)者經(jīng)常為 XML 的解析傷透了腦筋,無論是服務(wù)器端生成或處理 XML,還是客戶端用 JavaScript 解析 XML,都常常導(dǎo)致復(fù)雜的代碼,極低的開發(fā)效率。實際上,對于大多數(shù) Web 應(yīng)用來說,他們根本不需要復(fù)雜的 XML 來傳輸數(shù)據(jù),XML 的擴展性很少具有優(yōu)勢,許多 AJAX 應(yīng)用甚至直接返回 HTML 片段來構(gòu)建動態(tài) Web 頁面。和返回 XML 并解析它相比,返回 HTML 片段大大降低了系統(tǒng)的復(fù)雜性,但同時缺少了一定的靈活性。

            現(xiàn)在, JSON Web 應(yīng)用開發(fā)者提供了另一種數(shù)據(jù)交換格式。讓我們來看看 JSON 到底是什么,同 XML HTML 片段相比,JSON 提供了更好的簡單性和靈活性。

            clip_image001

            Ajax 資源中心

            請訪問 Ajax 資源中心,這是有關(guān) Ajax 編程模型信息的一站式中心,包括很多文檔、教程、論壇、blog、wiki 和新聞。任何 Ajax 的新信息都能在這里找到。

            JSON 數(shù)據(jù)格式解析

            XML 一樣,JSON 也是基于純文本的數(shù)據(jù)格式。由于 JSON 天生是為 JavaScript 準備的,因此,JSON 的數(shù)據(jù)格式非常簡單,您可以用 JSON 傳輸一個簡單的 StringNumberBoolean,也可以傳輸一個數(shù)組,或者一個復(fù)雜的 Object 對象。

            StringNumber Boolean JSON 表示非常簡單。例如,用 JSON 表示一個簡單的 String abc ”,其格式為:

            "abc"

             

            除了字符 "\/ 和一些控制符(\b\f,\n,\r,\t)需要編碼外,其他 Unicode 字符可以直接輸出。下圖是一個 String 的完整表示結(jié)構(gòu):


            1. String 的完整表示結(jié)構(gòu)
            clip_image002

            一個 Number 可以根據(jù)整型或浮點數(shù)表示如下:


            2. Number 的表示結(jié)構(gòu)
            clip_image003

            這與絕大多數(shù)編程語言的表示方法一致,例如:

            12345(整數(shù))

             -3.9e10(浮點數(shù))

             

            Boolean 類型表示為 true false 。此外,JavaScript 中的 null 被表示為 null,注意,truefalse null 都沒有雙引號,否則將被視為一個 String

            JSON 還可以表示一個數(shù)組對象,使用 [] 包含所有元素,每個元素用逗號分隔,元素可以是任意的 Value,例如,以下數(shù)組包含了一個 StringNumberBoolean 和一個 null

            ["abc",12345,false,null]

             

            Object 對象在 JSON 中是用 {} 包含一系列無序的 Key-Value 鍵值對表示的,實際上此處的 Object 相當(dāng)于 Java 中的 Map<String, Object>,而不是 Java Class 。注意 Key 只能用 String 表示。

            例如,一個 Address 對象包含如下 Key-Value

            city:Beijing

             street:Chaoyang Road

             postcode:100025(整數(shù))

             

            JSON 表示如下:

            {"city":"Beijing","street":" Chaoyang Road ","postcode":100025}

             

            其中 Value 也可以是另一個 Object 或者數(shù)組,因此,復(fù)雜的 Object 可以嵌套表示,例如,一個 Person 對象包含 name address 對象,可以表示如下:

            {"name":"Michael","address":

                {"city":"Beijing","street":" Chaoyang Road ","postcode":100025}

            }

             

            JavaScript 處理 JSON 數(shù)據(jù)

            上面介紹了如何用 JSON 表示數(shù)據(jù),接下來,我們還要解決如何在服務(wù)器端生成 JSON 格式的數(shù)據(jù)以便發(fā)送到客戶端,以及客戶端如何使用 JavaScript 處理 JSON 格式的數(shù)據(jù)。

            我們先討論如何在 Web 頁面中用 JavaScript 處理 JSON 數(shù)據(jù)。我們通過一個簡單的 JavaScript 方法就能看到客戶端如何將 JSON 數(shù)據(jù)表示給用戶:

            function handleJson() {

              var j={"name":"Michael","address":

                  {"city":"Beijing","street":" Chaoyang Road ","postcode":100025}

              };

              document.write(j.name);

              document.write(j.address.city);

             }

             

            假定服務(wù)器返回的 JSON 數(shù)據(jù)是上文的:

            {"name":"Michael","address":

                {"city":"Beijing","street":" Chaoyang Road ","postcode":100025}

            }

             

            只需將其賦值給一個 JavaScript 變量,就可以立刻使用該變量并更新頁面中的信息了,相比 XML 需要從 DOM 中讀取各種節(jié)點而言,JSON 的使用非常容易。我們需要做的僅僅是發(fā)送一個 Ajax 請求,然后將服務(wù)器返回的 JSON 數(shù)據(jù)賦值給一個變量即可。有許多 Ajax 框架早已包含了處理 JSON 數(shù)據(jù)的能力,例如 Prototype(一個流行的 JavaScript 庫:http://prototypejs.org提供了 evalJSON() 方法,能直接將服務(wù)器返回的 JSON 文本變成一個 JavaScript 變量:

            new Ajax.Request("http://url", {

              method: "get",

              onSuccess: function(transport) {

                var json = transport.responseText.evalJSON();

                // TODO: document.write(json.xxx);

              }

             });

             

            服務(wù)器端輸出 JSON 格式數(shù)據(jù)

            下面我們討論如何在服務(wù)器端輸出 JSON 格式的數(shù)據(jù)。以 Java 為例,我們將演示將一個 Java 對象編碼為 JSON 格式的文本。

            String 對象編碼為 JSON 格式時,只需處理好特殊字符即可。另外,必須用 (") 而非 (') 表示字符串:

             

             static String string2Json(String s) {

                StringBuilder sb = new StringBuilder(s.length()+20);

                sb.append('\"');

                for (int i=0; i<s.length(); i++) {

                    char c = s.charAt(i);

                    switch (c) {

                    case '\"':

                        sb.append("\\\"");

                        break;

                    case '\\':

                        sb.append("\\\\");

                        break;

                    case '/':

                        sb.append("\\/");

                        break;

                    case '\b':

                        sb.append("\\b");

                        break;

                    case '\f':

                        sb.append("\\f");

                        break;

                    case '\n':

                        sb.append("\\n");

                        break;

                    case '\r':

                        sb.append("\\r");

                        break;

                    case '\t':

                        sb.append("\\t");

                        break;

                    default:

                        sb.append(c);

                    }

                }

                sb.append('\"');

                return sb.toString();

             }

             

             

            Number 表示為 JSON 就容易得多,利用 Java 的多態(tài),我們可以處理 Integer,LongFloat 等多種 Number 格式:

             

             static String number2Json(Number number) { //---- 繼承關(guān)系

                return number.toString();

             }

             

             

            Boolean 類型也可以直接通過 toString() 方法得到 JSON 的表示

             

             static String boolean2Json(Boolean bool) {

                return bool.toString();

             }

             

             

            要將數(shù)組編碼為 JSON 格式,可以通過循環(huán)將每一個元素編碼出來:

             

             static String array2Json(Object[] array) {

                if (array.length==0)

                    return "[]";

                StringBuilder sb = new StringBuilder(array.length << 4);

                sb.append('[');

                for (Object o : array) {

                    sb.append(toJson(o));

                    sb.append(',');

                }

                // 將最后添加的 ',' 變?yōu)?span lang=EN-US> ']':

                sb.setCharAt(sb.length()-1, ']');

                return sb.toString();

             }

             

             

            最后,我們需要將 Map<String, Object> 編碼為 JSON 格式,因為 JavaScript Object 實際上對應(yīng)的是 Java Map<String, Object> 。該方法如下:

             

             static String map2Json(Map<String, Object> map) {

                if (map.isEmpty())

                    return "{}";

                StringBuilder sb = new StringBuilder(map.size() << 4);

                sb.append('{');

                Set<String> keys = map.keySet();

                for (String key : keys) {

                    Object value = map.get(key);

                    sb.append('\"');

                    sb.append(key);

                    sb.append('\"');

                    sb.append(':');

                    sb.append(toJson(value));

                    sb.append(',');

                }

                // 將最后的 ',' 變?yōu)?span lang=EN-US> '}':

                sb.setCharAt(sb.length()-1, '}');

                return sb.toString();

             }

             

             

            為了統(tǒng)一處理任意的 Java 對象,我們編寫一個入口方法 toJson(Object),能夠?qū)⑷我獾?span lang=EN-US> Java 對象編碼為 JSON 格式:

             

             public static String toJson(Object o) {

                if (o==null)

                    return "null";

                if (o instanceof String)

                    return string2Json((String)o);

                if (o instanceof Boolean)

                    return boolean2Json((Boolean)o);

                if (o instanceof Number)

                    return number2Json((Number)o);

                if (o instanceof Map)

                    return map2Json((Map<String, Object>)o);

                if (o instanceof Object[])

                    return array2Json((Object[])o);

                throw new RuntimeException("Unsupported type: " + o.getClass().getName());

             }

             

             

            我們并未對 Java 對象作嚴格的檢查。不被支持的對象(例如 List)將直接拋出 RuntimeException 。此外,為了保證輸出的 JSON 是有效的,Map<String, Object> 對象的 Key 也不能包含特殊字符。細心的讀者可能還會發(fā)現(xiàn)循環(huán)引用的對象會引發(fā)無限遞歸,例如,精心構(gòu)造一個循環(huán)引用的 Map,就可以檢測到 StackOverflowException

             

             @Test(expected=StackOverflowError.class)

             public void testRecurrsiveMap2Json() {

                Map<String, Object> map = new HashMap<String, Object>();

                map.put("key", map);

                JsonUtil.map2Json(map);

             }

             

             

            好在服務(wù)器處理的 JSON 數(shù)據(jù)最終都應(yīng)該轉(zhuǎn)化為簡單的 JavaScript 對象,因此,遞歸引用的可能性很小。

            最后,通過 Servlet MVC 框架輸出 JSON 時,需要設(shè)置正確的 MIME 類型(application/json)和字符編碼。假定服務(wù)器使用 UTF-8 編碼,則可以使用以下代碼輸出編碼后的 JSON 文本:

             

             response.setContentType("application/json;charset=UTF-8");

             response.setCharacterEncoding("UTF-8");

             PrintWriter pw = response.getWriter();

             pw.write(JsonUtil.toJson(obj));

             pw.flush();

             

             

            小結(jié)

            JSON 已經(jīng)是 JavaScript 標(biāo)準的一部分。目前,主流的瀏覽器對 JSON 支持都非常完善。應(yīng)用 JSON,我們可以從 XML 的解析中擺脫出來,對那些應(yīng)用 Ajax Web 2.0 網(wǎng)站來說,JSON 確實是目前最靈活的輕量級方案。

             

            clip_image005
            clip_image006

            clip_image008

             

            下載

            描述

            名字

            大小

            下載方法

            本文完整的源代碼

            jeedev-util.zip

            90 KB

            HTTP

             

            clip_image010

            clip_image011

            關(guān)于下載方法的信息

             

             

             

             

            posted on 2009-07-28 11:37 肥仔 閱讀(1511) 評論(0)  編輯 收藏 引用 所屬分類: Web-前臺

            五月丁香综合激情六月久久| 亚洲国产美女精品久久久久∴ | 99久久综合狠狠综合久久| 久久精品免费观看| 久久久久无码国产精品不卡| 久久久久久国产精品美女 | 97久久精品国产精品青草| 狠狠综合久久综合中文88| 久久亚洲中文字幕精品一区| 国产91久久精品一区二区| 无码国内精品久久综合88| 国产∨亚洲V天堂无码久久久| 青青青青久久精品国产h久久精品五福影院1421 | 国产精品美女久久福利网站| 91精品国产色综合久久| 久久只有这里有精品4| 69久久精品无码一区二区| 色综合久久久久综合99| 一本色道久久88加勒比—综合| 久久毛片一区二区| 久久青青草原亚洲av无码| 国产精品久久毛片完整版| 新狼窝色AV性久久久久久| 一本久久a久久精品综合香蕉| 久久久久久免费一区二区三区| 97久久国产综合精品女不卡 | 亚洲一区精品伊人久久伊人| 国内精品久久久久久久97牛牛| 亚洲天堂久久久| 日批日出水久久亚洲精品tv| 国产V综合V亚洲欧美久久| 久久精品国产99久久久| 99久久久国产精品免费无卡顿| 亚洲中文字幕无码久久精品1| 国产69精品久久久久APP下载 | 精品久久久久久国产91| 国产精品久久久久久影院| 久久精品亚洲日本波多野结衣 | 99久久夜色精品国产网站| 少妇内射兰兰久久| 亚洲乱亚洲乱淫久久|