成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

JSON是什么?為JavaScript準備的數據格式

開發 前端
本文介紹了JSON是什么。和 XML 一樣,JSON 也是基于純文本的數據格式。JSON 的數據格式非常簡單。

還不了解JSON是什么?看了下面這篇文章,您對JSON是什么應該能夠有了一個比較清晰的概念。

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

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

現在, JSON 為 Web 應用開發者提供了另一種數據交換格式。讓我們來看看 JSON 到底是什么,同 XML 或 HTML 片段相比,JSON 提供了更好的簡單性和靈活性。

JSON 數據格式解析

和 XML 一樣,JSON 也是基于純文本的數據格式。由于 JSON 天生是為 JavaScript. 準備的,因此,JSON 的數據格式非常簡單,您可以用 JSON 傳輸一個簡單的 String,Number,Boolean,也可以傳輸一個數組,或者一個復雜的 Object 對象。

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

"abc"

除了字符 ",\,/ 和一些控制符(\b,\f,\n,\r,\t)需要編碼外,其他 Unicode 字符可以直接輸出。 

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

  1. 12345(整數)  
  2.  -3.9e10(浮點數)  

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

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

["abc",12345,false,null]

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

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

  1. city:Beijing   
  2.  street:Chaoyang Road   
  3.  postcode:100025(整數)  

用 JSON 表示如下:

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

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

  1. {"name":"Michael","address":  
  2.     {"city":"Beijing","street":" Chaoyang Road ","postcode":100025}  
  3. }  

JavaScript. 處理 JSON 數據

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

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

  1. function handleJson() {   
  2.   var j={"name":"Michael","address":  
  3.       {"city":"Beijing","street":" Chaoyang Road ","postcode":100025}  
  4.   };   
  5.   document.write(j.name);   
  6.   document.write(j.address.city);   
  7.  }  

假定服務器返回的 JSON 數據是上文的:

  1. {"name":"Michael","address":  
  2.     {"city":"Beijing","street":" Chaoyang Road ","postcode":100025}  
  3. }  

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

  1. new Ajax.Request("http://url", {   
  2.   method: "get",   
  3.   onSuccess: function(transport) {   
  4.     var json = transport.responseText.evalJSON();   
  5.     // TODO: document.write(json.xxx);   
  6.   }   
  7.  });  

服務器端輸出 JSON 格式數據

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

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

  1. static String string2Json(String s) {   
  2.    StringBuilder sb = new StringBuilder(s.length()+20);   
  3.    sb.append('\"');   
  4.    for (int i=0; i<s.length(); i++) {   
  5.        char c = s.charAt(i);   
  6.        switch (c) {   
  7.        case '\"':   
  8.            sb.append("\\\"");   
  9.            break;   
  10.        case '\\':   
  11.            sb.append("\\\\");   
  12.            break;   
  13.        case '/':   
  14.            sb.append("\\/");   
  15.            break;   
  16.        case '\b':   
  17.            sb.append("\\b");   
  18.            break;   
  19.        case '\f':   
  20.            sb.append("\\f");   
  21.            break;   
  22.        case '\n':   
  23.            sb.append("\\n");   
  24.            break;   
  25.        case '\r':   
  26.            sb.append("\\r");   
  27.            break;   
  28.        case '\t':   
  29.            sb.append("\\t");   
  30.            break;   
  31.        default:   
  32.            sb.append(c);   
  33.        }   
  34.    }   
  35.    sb.append('\"');   
  36.    return sb.toString();   
  37. }   
  38.   

將 Number 表示為 JSON 就容易得多,利用 Java 的多態,我們可以處理 Integer,Long,Float 等多種 Number 格式:

  1. static String number2Json(Number number) {   
  2.    return number.toString();   
  3. }   
  4.   

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

  1. static String boolean2Json(Boolean bool) {   
  2.    return bool.toString();   
  3. }  

要將數組編碼為 JSON 格式,可以通過循環將每一個元素編碼出來:

  1. static String array2Json(Object[] array) {   
  2.    if (array.length==0)   
  3.        return "[]";   
  4.    StringBuilder sb = new StringBuilder(array.length << 4);   
  5.    sb.append('[');   
  6.    for (Object o : array) {   
  7.        sb.append(toJson(o));   
  8.        sb.append(',');   
  9.    }   
  10.    // 將最后添加的 ',' 變為 ']':   
  11.    sb.setCharAt(sb.length()-1, ']');   
  12.    return sb.toString();   
  13. }  

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

  1. static String map2Json(Map<String, Object> map) {   
  2.    if (map.isEmpty())   
  3.        return "{}";   
  4.    StringBuilder sb = new StringBuilder(map.size() << 4);   
  5.    sb.append('{');   
  6.    Set<String> keys = map.keySet();   
  7.    for (String key : keys) {   
  8.        Object value = map.get(key);   
  9.        sb.append('\"');   
  10.        sb.append(key);   
  11.        sb.append('\"');   
  12.        sb.append(':');   
  13.        sb.append(toJson(value));   
  14.        sb.append(',');   
  15.    }   
  16.    // 將最后的 ',' 變為 '}':   
  17.    sb.setCharAt(sb.length()-1, '}');   
  18.    return sb.toString();   
  19. }  

為了統一處理任意的 Java 對象,我們編寫一個入口方法 toJson(Object),能夠將任意的 Java 對象編碼為 JSON 格式:

  1. public static String toJson(Object o) {   
  2.     if (o==null)   
  3.         return "null";   
  4.     if (o instanceof String)   
  5.         return string2Json((String)o);   
  6.     if (o instanceof Boolean)   
  7.         return boolean2Json((Boolean)o);   
  8.     if (o instanceof Number)   
  9.         return number2Json((Number)o);   
  10.     if (o instanceof Map)   
  11.         return map2Json((Map<String, Object>)o);   
  12.     if (o instanceof Object[])   
  13.         return array2Json((Object[])o);   
  14.     throw new RuntimeException("Unsupported type: " + o.getClass().getName());   
  15.  }  

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

  1. @Test(expected=StackOverflowError.class)   
  2. public void testRecurrsiveMap2Json() {   
  3.    Map<String, Object> map = new HashMap<String, Object>();   
  4.    map.put("key", map);   
  5.    JsonUtil.map2Json(map);   

好在服務器處理的 JSON 數據最終都應該轉化為簡單的 JavaScript. 對象,因此,遞歸引用的可能性很小。

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

  1. response.setContentType("application/json;charset=UTF-8");   
  2. response.setCharacterEncoding("UTF-8");   
  3. PrintWriter pw = response.getWriter();   
  4. pw.write(JsonUtil.toJson(obj));   
  5. pw.flush();  

小結

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

JSON是什么,現在您應該了解了吧。

【編輯推薦】

  1. JavaBean到XML和JSON的轉換
  2. 詳談基于JSON的高級AJAX開發技術
  3. JSP實例詳解JavaBean應用步驟
  4. 詳解JSP中調用JavaBean
  5. JSP Servlet JavaBean在jdk6.0 Tomcat6.0下的構建
責任編輯:yangsai 來源: Java技術網
相關推薦

2010-01-06 14:04:55

Json數據格式

2014-08-12 10:15:42

數據格式JSONXML

2018-09-18 11:16:11

MapReduceXML大數據

2013-03-27 10:51:44

iOSjson解析網絡交互數據格式解析

2011-04-11 09:48:59

AjaxWEB服務

2024-04-15 13:13:04

PythonJSON

2010-01-06 13:23:20

JSON數據格式

2024-11-12 12:08:06

JSON數據技巧

2010-06-28 09:09:24

SQL Server

2021-11-11 23:16:33

前端數據格式Web

2021-04-26 07:51:00

JavaScript方法函數

2010-07-09 10:42:38

HART協議

2010-01-06 14:08:33

JSON WEB站點

2011-04-11 13:14:58

AjaxWEB服務

2010-07-09 10:27:33

SQL Server數

2022-06-05 14:57:35

發送釘釘運維架構

2024-12-19 00:12:02

APIJSON數據

2011-03-07 15:01:42

MySQLXML數據

2019-07-22 08:49:37

PythonJSON編程語言

2022-10-25 08:46:26

JSONJavaScript
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 美女日批免费视频 | 日韩精品免费 | 免费av电影网站 | 91在线视频国产 | 午夜黄色影院 | 国产精品久久久久久久久久妇女 | 亚洲444kkkk在线观看最新 | 欧美精品一区在线发布 | 伊人久麻豆社区 | 国产欧美精品一区二区色综合朱莉 | 成人在线中文字幕 | 毛片高清 | 欧美黑人狂野猛交老妇 | 四虎伊人| 啪啪免费网 | 中文字幕一区二区三区在线观看 | 天堂一区二区三区 | 毛片免费观看 | 久久99精品久久久久婷婷 | 国产日韩一区二区三免费高清 | av网站免费在线观看 | 欧美极品一区二区 | 91在线电影 | 亚洲精品久久久一区二区三区 | 国产一区在线免费观看视频 | 成人国产精品久久久 | 欧美a区 | 婷婷亚洲综合 | 国产精品久久久久久久久久 | 九一视频在线观看 | 国产激情三区 | 国产福利在线视频 | 欧美精 | 91动漫在线观看 | 欧美性一区二区三区 | 成人福利电影 | 亚洲免费网址 | 激情 亚洲| 国产精品日韩在线观看一区二区 | 人人干在线视频 | 日韩视频区 |