DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> XML學習教程 >> XML詳解 >> 大致說明JSON 對象的相關使用字符
大致說明JSON 對象的相關使用字符
編輯:XML詳解     

簡單地說,JSON 對象可以將 JavaScript 對象中表示的一組數據轉換為字符串,然後就可以在函數之間輕松地傳遞這個字符串,或者在異步應用程序中將字符串從 Web 客戶機傳遞給服務器端程序。

這個字符串看起來有點兒古怪(稍後會看到幾個示例),但是 JavaScript 很容易解釋它,而且 JSON 可以表示比名稱/值對更復雜的結構。例如,可以表示數組和復雜的對象,而不僅僅是鍵和值的簡單列表。

當需要表示一組值時,JSON 不但能夠提高可讀性,而且可以減少復雜性:

  1. { "programmers": [  
  2.     { "firstName": "Brett", "lastName":"McLaughlin", "email": "brett@newInstance.com" },  
  3.     { "firstName": "Jason", "lastName":"Hunter", "email": "jason@servlets.com" },  
  4.     { "firstName": "Elliotte", "lastName":"Harold", "email": "elharo@Macfaq.com" }  
  5.    ],  
  6. "authors": [  
  7.     { "firstName": "Isaac", "lastName": "Asimov", "genre": "scIEnce fiction" },  
  8.     { "firstName": "Tad", "lastName": "Williams", "genre": "fantasy" },  
  9.     { "firstName": "Frank", "lastName": "Peretti", "genre": "christian fiction" }  
  10.    ],  
  11. "musicians": [  
  12.     { "firstName": "Eric", "lastName": "Clapton", "instrument": "guitar" },  
  13.     { "firstName": "Sergei", "lastName": "Rachmaninoff", "instrument": "piano" }  
  14.    ]  

至此,您應該從技術角度對如何在服務器端處理 JSON 有了基本的把握。本篇文章和本系列的 第 10 部分 不僅提供了技術層面的幫助,而且還向您展示了 JSON 是一種多麼靈活、強大的數據格式。即使您不會在每個應用程序中都使用 JSON,但優秀的 AJax 和 JavaScript 程序員的工具箱中總少不了 JSON 以備不時之需。

  • 詳細參數JSON概念的學習與切磋
  • 專家充分介紹JSON的優勢所在說明
  • 圖示法進行JSON結構的說明指導
  • 闡述JSON轉化的結構事實說明介紹
  • 如何更好的進行XML轉換為JSON問題介紹

我當然很希望能夠分享您的JSON 對象使用經驗以及您對何種語言更善於在服務器端處理 JSON 數據的高見。您可以訪問 Java 和 XML 新聞組(有關鏈接,請參閱 參考資料 部分)跟我聯系。享受JSON 對象和文本數據格式的樂趣吧。

  1. public void doPost(HttpServletRequest request, HttpServletResponse response)  
  2. throws ServletException, IOException {  
  3.  
  4. StringBuffer jb = new StringBuffer();  
  5. String line = null;  
  6. try {  
  7.     BufferedReader reader = request.getReader();  
  8.     while ((line = reader.readLine()) != null)  
  9.       jb.append(line);  
  10. } catch (Exception e) { //report an error }  
  11.  
  12. try {  
  13.     JSONObject JSonObject = new JSONObject(jb.toString());  
  14. } catch (ParseException e) {  
  15.     // crash and burn  
  16.     throw new IOException("Error parsing JSON request string");  
  17. }  
  18.  
  19. // Work with the data using methods like...  
  20. // int someInt = JSonObject.getInt("intParamName");  
  21. // String someString = JSonObject.getString("stringParamName");  
  22. // JSONObject nestedObj = JSonObject.getJSONObject("nestedObjName");  
  23. // JSONArray arr = JSonObject.getJSONArray("arrayParamName");  
  24. // etc...  

盡管看起來不明顯,但是上面的長字符串實際上只是一個數組;將這個數組放進 Javascript 變量之後,就可以很輕松地訪問它。實際上,只需用點號表示法來表示數組元素。所以,要想訪問 programmers 列表的第一個條目的姓氏,只需在 JavaScript 中使用下面這樣的代碼:

  1. String newJSONtext = people.toJSONString();     //value is "McLaughlin" 

不管在服務器端使用何種語言,在服務器端處理JSON 對象基本上就需要兩個步驟:
1.針對編寫服務器端程序所用的語言,找到相應的 JSON 解析器/工具箱/幫助器 API。
2.使用 JSON 解析器/工具箱/幫助器 API 取得來自客戶機的請求數據並將數據轉變成腳本能理解的東西。

XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved