`
zz563143188
  • 浏览: 2274386 次
  • 性别: Icon_minigender_1
  • 来自: 珠海
博客专栏
77fc734c-2f95-3224-beca-6b8da12debc8
编程工具介绍
浏览量:578585
D9710da2-8a00-3ae6-a084-547a11afab81
Spring Mvc实战(...
浏览量:1087483
D3f88135-07de-3968-a0f0-d2f13428c267
项目开发经验
浏览量:1656710
社区版块
存档分类
最新评论

JSON入门小例子

阅读更多

 

 

企业级项目实战(带源码)地址http://zz563143188.iteye.com/blog/1825168

收集五年的开发资料下载地址:  http://pan.baidu.com/share/home?uk=4076915866&view=share

JSON入门

  •  什么是JSON       

      JSON(JavaScript Object Notation http://www.json .org/json -zh.html ),是一种轻量级的基于文本且独立于语言的数据交换格式,比XML更轻巧,它是XML数据交换的一个替代方案。它源于ECMAScript程序语言标准-第3版(ECMA-262 3rd Edition - December 1999)的子集,定义了便于表示结构化数据的一套格式规范,JSON规范是符合ECMAScript语法规范,这样按JSON规范描述出的字符串已是 JavaScript的原生代码串,这使之能通过eval动态的在JSON串与JavaScript对象之间进行转换。如果夸大来说,它是另一种理想的但有别于XML数据交换语言。

  •  JSON建构于两种结构

        “名称/值”对的集合(A collection of name/value pairs)。不同的语言中,它被理解为对象(object),纪录(record),结构(struct),字典(dictionary),哈希表(hash table),有键列表(keyed list),或者关联数组 (associative array)。


值的有序列表(An ordered list of values)。在大部分语言中,它被理解为数组(array)。


这些都是常见的数据结构。事实上大部分现代计算机语言都以某种形式支持它们。这使得一种数据格式在同样基于这些结构的编程语言之间交换成为可能。

  •  JSON语法规则

        对象是一个无序的“‘名称/值’对”集合。一个对象以“{”(左括号)开始,“}”(右括号)结束。每个“名称”后跟一个“:”(冒号);“‘名称/值’ 对”之间使用“,”(逗号)分隔。


        数组是值(value)的有序集合。一个数组以“[”(左中括号)开始,“]”(右中括号)结束。值之间使用“,”(逗号)分隔。


        值(value)可以是双引号括起来的字符串(string)、数值(number)、true、false、 null、对象(object)或者数组(array)。这些结构可以嵌套。


         字符串(string)是由双引号包围的任意数量Unicode字符的集合,使用反斜线转义。一个字符(character)即一个单独的字符串(character string)。与C或者Java的字符串非常相似。

  •  快速浏览JSON与XML表现形式

         假如有一个employee对象,它有“姓、名、员工编号、头衔”等信息,先看看JSON是如何来描述它的:

Js代码  收藏代码
  1. {  
  2.     employee :  
  3.     {  
  4.         firstName: "John",  
  5.         lastName : "Doe",  
  6.         employeeNumber : 123,  
  7.         title : "Accountant"  
  8.     }  
  9. }   

       再来看看XML是如何表示的,请看:

Xml代码  
  1. <employee>  
  2.     <firstName>John</firstName>  
  3.     <lastName>Doe</lastName>  
  4.     <employeeNumber>123</employeeNumber>  
  5.     <title>Accountant</title>  
  6. </employee>   

      从上面描述看,JSON表示法不正是JavaScript中对象描述的一种方式么?正确,这正是JavaScript中的对象构造的原生代码。既然是原生代码,我们把它转换成JavaScript中的对象,这样我们操作对象就比操作字符串方便多了。 
      把JSON字符串转换成JavaScript对象:

Js代码  
  1. <script type="text/javascript">  
  2.         //使用script本身的函数eval将JSON串解析成对象  
  3.     var e = eval(  
  4.                     '({' +  
  5.                     'employee : ' +  
  6.                     '{' +  
  7.                         'firstName: "John",' +  
  8.                         'lastName : "Doe",' +  
  9.                         'employeeNumber : 123,' +  
  10.                         'title : "Accountant"' +  
  11.                     '}' +  
  12.                     '})'  
  13.                 );  
  14.         //现在我们可以使用e这个对象了,还可以以点的访问形式来访问对象的属性  
  15.     alert(e.employee.firstName);  
  16.     alert(e.employee.lastName);  
  17.     alert(e.employee.employeeNumber);  
  18.     alert(e.employee.title);  
  19. </script>   

      看完上述后我们来对比它们。

 

  •  XML与JSON比对

       经过一番快速浏览后如何?感觉到没有JSON的设计上比XML更轻巧简洁?先前就说过了,正是它符合JavaScript语言对象本身特点,这使得如果服务器传来的文本是符合JavaScript语法定义语句的字符串,那岂不是一条eval方法就能解析了?的确如此~

       从上面两者的表示来看,JSON表示法在语法上要比XML要简洁的多,由于不需要使用关闭标签来呼应开始标签,因此许多多余的信息不再出现了,相对XML而言基本上不存在数据冗余,这在传输与响应速度上大在提高了。

       另外,JSON不只是在表现形式上有如此的优势,最重要的是可以丢弃以前弄得我们晕头转向的DOM解析了(客户端的JavaScript的XML DOM解析,服务器端的DOM、SAX、Dom4j、Jdom等)。JSON与XML相比对JavaScript有着更好的通用性,一段JSON格式数据经过JavaScript一个简单的方法(eval)即可转换成 JavaScript对象供程序调用,转换方法是浏览器的JavaScript内部定义好的无需再手工编写。而一段XML格式的数据需要调用浏览器内部的 XML解析器工具进行解析后才可以使用。而对于不同内核的浏览器(如IE、Netscape等)XML解析的方法是有差别的,因此需要针对不同浏览器内核做不同的方法封装,从而给客户端开发带来一定的复杂度。相比之下JSON被浏览器解析的速度更快。在服务器端不同的语言也有不同的JSON解析器,可以很方便的解析客户端传过来的字符串,而不像为了读取XML还是借助于这样或那样的API工具。

  •  JSON优缺点

优点:

  乍看上去,使用JSON的数据分隔符的优点可能并不那么明显,但存在一个根本性的缘由:它们简化了数据访问。使用这些数据分隔符时, JavaScript引擎对数据结构(如字符串、数组、对象)的内部表示恰好与这些符号相同。


  JSON的另一个优点是它的非冗长性。在XML中,打开和关闭标记是必需的,这样才能满足标记的依从性;而在JSON中,所有这些要求只需通过一个简单的括号即可满足。在包含有数以百计字段的数据交换中,传统的XML标记将会延长数据交换时间


  此外,JSON受到了擅长不同编程语言的开发人员的青睐。这是因为无论在Haskell中或 Lisp中,还是在更为主流的C#和Java中,开发都可以方便地生成JSON。

 

不足:

  和许多好东西都具有两面性一样,JSON的非冗长性也不例外,为此JSON丢失了XML具有的一些特性。命名空间允许不同上下文中的相同的信息段彼此混合,然而,显然在JSON中已经找不到了命名空间。JSON与XML的另一个差别是属性的差异,由于JSON采用冒号赋值,这将导致当XML转化为 JSON时,在标识符(XML CDATA)与实际属性值之间很难区分谁应该被当作文本考虑。 
  另外,JSON片段的创建和验证过程比一般的XML稍显复杂。从这一点来看,XML在开发工具方面领先于JSON。

JSON实践

预备知识

  •  动态脚本函数eval ()

      在进一步学习之前,我们有必要讲解一下eval方法的用法,懂的同学可以跳过。

 

      eval() 函数可计算某个字符串,并执行其中的的 JavaScript 代码。它接收一个参数s,如果s不是字符串,则直接返回s。否则执行s语句。如果s语句执行结果是一个值,则直接返回此值,否则返回undefined。

 

      另外,该方法只接受原始字符串作为参数,如果 string 参数不是原始字符串,那么该方法将不作任何改变地返回。因此请不要为 eval() 函数传递 String 对象来作为参数:

Js代码  
  1. var str = new String("alert('msg')");  
  2. //请不要传递String对象,否则直接返回string对象了  
  3. alert(eval(str)==str);//true  
  4.   
  5. //应该传递原始string字符串,这样才看作JavaScript脚本并执行   
  6. eval("alert('msg')");//msg  

      最后,需要特别注意的是对象声明语法“{}”并不能返回一个值,需要用括号括起来才会返回值(括号里的脚本是表达式,有返回值,而不是无返回值的逻辑式,因为大括号里的脚本又可能是表达式,又可能是普通的逻辑表达,所以用小括号括起来后明确的说明是值表达式):

Js代码  
  1. var str="{}";//花括号内没属性时  
  2. alert(eval('(' + str + ')'));//弹出:[object Object]  
  3. alert(eval(str));//弹出:undefined  
  4.   
  5. str="{name:'jzj'}";//花括号内有一个属性  
  6. alert(typeof eval('(' + str + ')'));//弹出:object,以对象方式返回  
  7. alert(eval(str));//弹出:jzj  
  8. alert(eval('(' + str + ')').name);//弹出:jzj  
  9. alert(eval(str).name);//弹出:undefined  
  10.   
  11. str="{name:'jzj',age:30}";//花括号内有多个属性时  
  12. alert(eval('(' + str + ')'));//  
  13. alert(eval('(' + str + ')').name);//jzj  
  14. alert(eval('(' + str + ')').age);//30  
  15. //alert(eval(str));//运行时会出错,多个属性时不用小括号运行出错  

      可以看到,对于对象声明语句来说,仅仅是执行,并不能返回值 。为了返回常用的“{}”这样的对象声明语句,必须用括号括住,以将其转换为表达式,才能返回其值 。这也是使用JSON来进行Ajax开发的基本原理之一。

 

     现来说说本节的重点,就是在应用eval时,动态脚本所生成的变量都局部的,但很多时候我们可能在调用eval函数的外面使用生成的变量,eval不可能在全局空间内执行,这就给开发带来了不少问题,这该如何作?请看继续往下看吧。

 

     我们先来证实一下eval产生的变量是局部性的,在调用eval函数外是不能访问到此变量的。

Js代码  
  1. var str='全局';//定义一个全局变量  
  2. function test(){  
  3.     eval('var str="局部"');  
  4.     alert(str);//局部  
  5. }  
  6. test();  
  7. alert(str);    //弹出:全局  

   另外,eval生成的函数也是局部的,它只能在生成它的函数内使用,出函数域就不能调用的到。

 

      解决办法:

Js代码  
  1. function gloablEval(code){  
  2.     if(window.attachEvent && !window.opera){  
  3.       //ie  
  4.       execScript(code);   
  5.     }else{  
  6.       //not ie window对象不能省,否则生成的变量在执行的函数外不可见  
  7.       window.eval(code);  
  8.       alert(str);//局部  
  9.       //eval(code);  
  10.       //alert(str);//局部  
  11.     }  
  12. }  
  13. var str='全局';//定义一个全局变量  
  14. gloablEval('var str="局部"');  
  15. alert(str);    //弹出:局部,这里用局部的履盖了全局变量的值  

       现解释一下:

      1、对于IE浏览器,默认已经提供了这样的函数:execScript,用于在全局空间执行代码。
      2、对于Firefox浏览器,直接调用eval函数,则在调用者的空间执行;如果调用window.eval则在全局空间执行。

  •  JavaScript中的JSON

       我们知道,可以使用eval()方法调用JavaScript的编译器把JSON文本转变成对象。因为JSON是JavaScript的一个确切的子集,编译器可以正确地解析JSON文本,然后生成一个对象结构。

Js代码  
  1. var myObject = eval('(' + myJSONtext + ')');  

 

      eval函数非常快速。它可以编译执行任何JavaScript程序,因此产生了安全性问题。当使用可信任与完善的源代码时才可以使用eval函数。这样可以更安全的使用JSON解析器。使用XMLHttpRequest的web应用,页面之间的通讯只允许同源,因此是可以信任的。但这却不是完善的。如果服务器没有严谨的JSON编码,或者没有严格的输入验证,那么可能传送包括危险脚本的无效JSON文本。eval函数将执行恶意的脚本。

      如果关心安全的话,使用JSON解析器可以防止此类事件。JSON解析器只能辨识JSON文本,拒绝所有脚本,因此它比较安全,JSON官方网站提供的一个开源的JSON解析器和字符串转换器(http://www.json.org/json.js )。

Js代码  
  1. var myObject = myJSONtext.parseJSON();  

      而JSON的字符串转换器(stringifier)则作相反的工作,它将JavaScript数据结构转换为JSON文本。JSON是不支持循环数据结构的,所以注意不能把循环的结构交给字符串转换器。

Js代码  
  1. var myJSONText = myObject.toJSONString();  
  •    Java中的JSON

      Java中的JSON解释器官方提供了好几种,我们这里使用的是org.json 包,关于如何使用,请参见另一篇《JSON之org.json包测试》 ,它是基于官方包提供的测试改写而来的。

开始实战

       本实例实现了客户端与服务器端通过JSON进行参数的传递与接收,而不是通过原来的XML方式进行通信。页面采用了Prototype的Ajax方式进行异步通信,并采用了官方json.js 进行对象与JSON串的灵活互转。服务器端采用了官方提供org.json 包进行JSON串与Java对象的互转。具体的细节请看代码注释。

       客户端实现:

页面代码清单代码  
  1. <html>   
  2. <head>   
  3. <title> JSON Address Book </title>   
  4.   
  5. </head>  
  6. <body>   
  7. <div style="text-align:left" id="addressBookResults"></div>  
  8.   
  9. <script type="text/javascript" src="prototype-1.4.0.js"></script>   
  10. <script type="text/javascript" src="json.js"></script>   
  11. <script type="text/javascript">  
  12. //address对象  
  13. function address(city,street,zip){  
  14.     this.city = city;//城市  
  15.     this.street = street;//街道  
  16.     this.zip = zip;//邮编  
  17. }  
  18. //addressbook对象  
  19. function addressbook(city,street,zip,name,tel1,tel2){  
  20.     //addressbook对象中含有address对象属性  
  21.     this.address = new address(city,street,zip);  
  22.     //人的名字属性  
  23.     this.name = name;  
  24.     //人的电话号码属性,且有两个电话号码  
  25.     this.phoneNumbers = [tel1,tel2];  
  26. }  
  27. //创建两个addressbook对象实例,这些信在实际的项目中是由用户通过页面输入的  
  28. var addressbookObj1 = new addressbook("Seattle, WA","P.O BOX 54534",  
  29.                                         42452,"Ann Michaels",  
  30.                                         "561-832-3180","531-133-9098");  
  31. var addressbookObj2 = new addressbook("Miami, FL","53 Mullholand Drive",  
  32.                                         72452,"Betty Carter",  
  33.                                         "541-322-1723","546-338-1100");  
  34.   
  35. //创建要传递给后台的参数对象  
  36. var paramObj={};  
  37. //因为有多个(这里是两个),我们用数组的形式  
  38. paramObj.addressbook=new Array(addressbookObj1,addressbookObj2);  
  39.   
  40. //通过对象实例的toJSONString方法,JavaScript对象转JSON串  
  41. var param = paramObj.toJSONString();  
  42. //alert(param);  
  43.   
  44. // 定义 service URL   
  45. var url = '/json_addressbook/addrbk?timeStamp='+new Date();  
  46.   
  47. // 通过原型创建AJAX请求的WEB服务, 响应后, 回调 showResponse 方式        
  48. new Ajax.Request( url, { method: 'post', parameters:"jsonStr="+param,   
  49.                             onComplete: callBack });  
  50.   
  51. // 回调方法,接收服务器返回过来的JSON串,  
  52. //并用eval函数或String对象实例parseJSON转换成JavaScript对象  
  53. function callBack(originalRequest)  {  
  54.     // 获取服务器返回的JSON原始串   
  55.     var jsonRaw = originalRequest.responseText;  
  56.     //原始串转换成JavaScript对象  
  57.     //var jsonRawObj = eval("(" + jsonRaw + ")");用此种方式也行  
  58.     var jsonRawObj = jsonRaw.parseJSON();  
  59.       
  60.     //从json原始对象中提取HTML格式串  
  61.     var jsonHtmlStr = jsonRawObj.jsonHtmlStr;  
  62.     //提取AddreeBook的JSON串  
  63.     var jsonCode = jsonRawObj.jsonCode;  
  64.     // 通过eval动态的把JSON响应串构造成JavaScript对象  
  65.     //var jsonContent = jsonCode.parseJSON();用此种方式也行  
  66.     jsonContent = eval("(" + jsonCode + ")");     
  67.       
  68.     // 从服务器获取的JSON格式串后,显示数据到页面      
  69.     finalResponse = "<b>服务器返回的JSON串如下: </b><br/><br>";  
  70.     finalResponse +=  jsonHtmlStr+"<br/>";  
  71.     finalResponse +=  "<br><b>从JSON对象提取信息如下: </b><br/><br>";  
  72.     // 根据地址薄长度循环.  
  73.     for (i = 0; i < jsonContent.addressbook.length; i++) {  
  74.          finalResponse += "<hr/>";  
  75.          finalResponse += "<i>Name:</i> " + jsonContent.addressbook[i].name + "<br/>";     
  76.          finalResponse += "<i>Address:</i> " + jsonContent.addressbook[i].address.street   
  77.                             + " -- " +   
  78.                            jsonContent.addressbook[i].address.city[0] + "," +             
  79.                            jsonContent.addressbook[i].address.zip + ".<br/>";            
  80.          finalResponse += "<i>Telephone numbers:</i> "   
  81.                         + jsonContent.addressbook[i].phoneNumbers[0] + " &amp; " +   
  82.          jsonContent.addressbook[i].phoneNumbers[1] + ".";            
  83.     }  
  84.     // 把结果置换到结果区域并显示  
  85.     document.getElementById("addressBookResults").innerHTML = finalResponse;  
  86. }  
  87. </script>   
  88. </body>   
  89. </html>   

         页面展示结果:

  JSON Address Book
服务器返回的JSON串如下: 

{"addressbook": [
    {
        "address": {
            "city": [
                "Seattle, WA",
                "changsha"
            ],
            "street": ["P.O BOX 54534"],
            "zip": [42452]
        },
        "name": "Ann Michaels",
        "phoneNumbers": [
            "561-832-3180",
            "531-133-9098"
        ]
    },
    {
        "address": {
            "city": [
                "Miami, FL",
                "changsha"
            ],
            "street": ["53 Mullholand Drive"],
            "zip": [72452]
        },
        "name": "Betty Carter",
        "phoneNumbers": [
            "541-322-1723",
            "546-338-1100"
        ]
    }
]}

从JSON对象提取信息如下: 


Name: Ann Michaels
Address: P.O BOX 54534 -- Seattle, WA,42452.
Telephone numbers: 561-832-3180 & 531-133-9098.
Name: Betty Carter
Address: 53 Mullholand Drive -- Miami, FL,72452.
Telephone numbers: 541-322-1723 & 546-338-1100.

          服务器端实现:

Java代码  
  1. package orgjson;  
  2.   
  3. import java.io.IOException;  
  4. import java.util.Iterator;  
  5. import java.util.Map;  
  6. import java.util.SortedMap;  
  7. import java.util.TreeMap;  
  8.   
  9. import javax.servlet.ServletException;  
  10. import javax.servlet.http.HttpServlet;  
  11. import javax.servlet.http.HttpServletRequest;  
  12. import javax.servlet.http.HttpServletResponse;  
  13.   
  14. import org.json.JSONArray;  
  15. import org.json.JSONException;  
  16. import org.json.JSONObject;  
  17.   
  18. import bean.Address;  
  19.   
  20. /** 
  21.  * 使用 org.josn 包进行解析操作 
  22.  * (C) 2009-9-1, jzjleo   
  23.  */  
  24. public class AddressServlet extends HttpServlet {  
  25.   
  26.     private static final long serialVersionUID = -1762985503942785440L;  
  27.   
  28.     protected void service(HttpServletRequest req, HttpServletResponse resp)  
  29.             throws ServletException, IOException {  
  30.         // 创建addressbook数据结构  
  31.         SortedMap addressBook = new TreeMap();  
  32.   
  33.         // 创建新的address实体并放置到Map中  
  34.         Address annMichaels = new Address("P.O BOX 54534""Seattle, WA"42452,  
  35.                 "561-832-3180""531-133-9098");  
  36.         addressBook.put("Ann Michaels", annMichaels);  
  37.   
  38.         Address bettyCarter = new Address("53 Mullholand Drive""Miami, FL"72452,  
  39.                 "541-322-1723""546-338-1100");  
  40.         addressBook.put("Betty Carter", bettyCarter);  
  41.   
  42.         try {  
  43.   
  44.             // 准备转换通讯簿映射到JSON数组   
  45.             // 数组用于放置多个地址条目  
  46.             JSONArray jsonAddressBook = new JSONArray();  
  47.   
  48.             // 迭代过滤地址簿条目  
  49.             for (Iterator iter = addressBook.entrySet().iterator(); iter.hasNext();) {  
  50.   
  51.                 // 找当前迭代项   
  52.                 Map.Entry entry = (Map.Entry) iter.next();  
  53.                 String key = (String) entry.getKey();  
  54.                 Address addressValue = (Address) entry.getValue();  
  55.   
  56.                 // 以键值对的形式存入条目并分配给"name"  
  57.                 JSONObject jsonResult = new JSONObject();  
  58.                 jsonResult.put("name", key);  
  59.   
  60.                 // 获取和创造相应的地址结构,綁定到新Key  
  61.                 // 追加地址条目到JSON格式结果   
  62.                 String streetText = addressValue.getStreet();  
  63.                 String cityText = addressValue.getCity();  
  64.                 int zipText = addressValue.getZip();  
  65.   
  66.                 //--注:Bean可以直接转换成JSON串,下面可以采用 new JSONObject(addressValue)  
  67.                 //形式来自动转换成JSON串  
  68.                 JSONObject jsonAddrObj = new JSONObject();  
  69.   
  70.                 //以数组的形式存放,street为存放数组的变量名即Key,如果key不存在,则新建,如果存在, 
  71.                 //则在原来数组后追加  
  72.                   
  73.                 //jsonAddress.append("street", streetText);  
  74.                 //上句等价于下面语句   
  75.                 jsonAddrObj.put("street"new JSONArray().put(streetText));  
  76.                 jsonAddrObj.append("city", cityText);  
  77.                 jsonAddrObj.append("city""changsha");//追加  
  78.                 //上两句等价于如下语句  
  79.                 //jsonAddrObj.put("city", new  JSONArray().put(cityText).put("changsha")); 
  80.                 jsonAddrObj.append("zip"new Integer(zipText));  
  81.                 jsonResult.put("address", jsonAddrObj);  
  82.   
  83.                 // 获取和结构,建立相应的电话到新的Key   
  84.                 // 追加在电话条目到JSON格式的结果里  
  85.                 String telText = addressValue.getTel();  
  86.                 String telTwoText = addressValue.getTelTwo();  
  87.                 JSONArray jsonTelephones = new JSONArray();  
  88.                 jsonTelephones.put(telText);  
  89.                 jsonTelephones.put(telTwoText);  
  90.                 jsonResult.put("phoneNumbers", jsonTelephones);  
  91.   
  92.                 // 把JSON地址条目放置到全局的JSON地址薄数组里  
  93.                 jsonAddressBook.put(jsonResult);  
  94.             } // 结束循环地址薄   
  95.   
  96.             // 赋值JSON地址薄到结果字符变量   
  97.             JSONObject resultJsonObj = new JSONObject().put("addressbook",  
  98.                     jsonAddressBook);  
  99.   
  100.             //格式化输出到页面上的JSON串  
  101.             String jsonHtmlStr = resultJsonObj.toString(4).replaceAll(" ""&nbsp;")  
  102.                     .replaceAll("\n""<br>");  
  103.   
  104.             JSONObject jsonObj = new JSONObject().put("jsonHtmlStr", jsonHtmlStr).put(  
  105.                     "jsonCode", resultJsonObj.toString());  
  106.             // 返回JSON串  
  107.             resp.getOutputStream().write(jsonObj.toString().getBytes());  
  108.   
  109.             System.out.println(resultJsonObj.toString(4));  
  110.             //System.out.println(jsonObj.toString(4));  
  111.             System.out.println("-----------------------------------------------");  
  112.             readJSONString(req);  
  113.         } catch (Exception e) {  
  114.             e.printStackTrace();  
  115.         }  
  116.   
  117.     }  
  118.   
  119.     /** 
  120.      * 从客户端读取JSON串 
  121.      * @param req 
  122.      */  
  123.     public void readJSONString(HttpServletRequest req) {  
  124.         System.out.println("接收到客户端的JSON信息如下:");  
  125.         JSONObject clientJSONObj;  
  126.         try {  
  127.             clientJSONObj = new JSONObject(req.getParameter("jsonStr"));  
  128.   
  129.             System.out.println(clientJSONObj.toString(4));  
  130.             JSONArray addressbookArray = clientJSONObj.getJSONArray("addressbook");  
  131.             for (int i = 0; i < addressbookArray.length(); i++) {  
  132.                 System.out.println("The" + " " + (i + 1) + " addressbook msg:");  
  133.                 JSONObject addressbookJSONObj = addressbookArray.getJSONObject(i);  
  134.                 JSONObject addressJSONObj = addressbookJSONObj.getJSONObject("address");  
  135.                 System.out.println("address-------");  
  136.                 System.out.println("           " + addressJSONObj.getString("city"));  
  137.                 System.out.println("           " + addressJSONObj.getString("street"));  
  138.                 System.out.println("           " + addressJSONObj.getString("zip"));  
  139.                 System.out.println("name----------");  
  140.                 System.out.println("           " + addressbookJSONObj.getString("name"));  
  141.                 System.out.println("phoneNumbers--");  
  142.                 JSONArray phoneNumbersArr = addressbookJSONObj  
  143.                         .getJSONArray("phoneNumbers");  
  144.                 System.out.println("           " + phoneNumbersArr.getString(0));  
  145.                 System.out.println("           " + phoneNumbersArr.getString(1));  
  146.                 System.out.println();  
  147.             }  
  148.         } catch (JSONException e) {  
  149.             e.printStackTrace();  
  150.         }  
  151.     }  
  152. }  

 

          服务器后台打印:

{"addressbook": [
    {
        "address": {
            "city": [
                "Seattle, WA",
                "changsha"
            ],
            "street": ["P.O BOX 54534"],
            "zip": [42452]
        },
        "name": "Ann Michaels",
        "phoneNumbers": [
            "561-832-3180",
            "531-133-9098"
        ]
    },
    {
        "address": {
            "city": [
                "Miami, FL",
                "changsha"
            ],
            "street": ["53 Mullholand Drive"],
            "zip": [72452]
        },
        "name": "Betty Carter",
        "phoneNumbers": [
            "541-322-1723",
            "546-338-1100"
        ]
    }
]}
-----------------------------------------------
接收到客户端的JSON信息如下:
{"addressbook": [
    {
        "address": {
            "city": "Seattle, WA",
            "street": "P.O BOX 54534",
            "zip": 42452
        },
        "name": "Ann Michaels",
        "phoneNumbers": [
            "561-832-3180",
            "531-133-9098"
        ]
    },
    {
        "address": {
            "city": "Miami, FL",
            "street": "53 Mullholand Drive",
            "zip": 72452
        },
        "name": "Betty Carter",
        "phoneNumbers": [
            "541-322-1723",
            "546-338-1100"
        ]
    }
]}
The 1 addressbook msg:
address-------
           Seattle, WA
           P.O BOX 54534
           42452
name----------
           Ann Michaels
phoneNumbers--
           561-832-3180
           531-133-9098

The 2 addressbook msg:
address-------
           Miami, FL
           53 Mullholand Drive
           72452
name----------
           Betty Carter
phoneNumbers--
           541-322-1723
           546-338-1100
分享到:
评论
2 楼 lixinghua350823 2014-03-06  
引用
引用
引用
1 楼 it2013 2013-12-31  
牛啊,转了

相关推荐

    JSONF示例,JSON入门案例,JSON

    在这个"JSONF示例,JSON入门案例"中,我们有两个文件:`index.html`和`pro.php`。这个实例主要展示了如何通过AJAX(异步JavaScript和XML)从服务器端的PHP文件获取并处理JSON数据。 首先,`index.html`是一个HTML...

    json 入门 案列 很简单

    在压缩包中的"json入门(1)"文件,可能是包含了一些基本的JSON数据示例或者练习,用来帮助学习者动手操作,理解如何创建、解析和使用JSON。通过实际操作,你可以更加深入地了解JSON的语法和特性,同时掌握如何在AJAX...

    Json 入门学习资料

    以下是一些关于JSON的基础知识和入门要点: 1. **JSON的结构**: JSON主要由两种基本结构组成: - 对象(Object):以花括号 `{}` 包裹,内部由一系列键值对(Key-Value)构成,键和值之间用冒号 `:` 分隔,键值...

    JSON入门教程-非常实用的JSON课件

    ### JSON入门教程——非常实用的JSON课件 #### 一、JSON简介 JSON(JavaScript Object Notation)是一种轻量级的数据交换格式。它基于一种简单的数据结构:对象和数组,易于人阅读和编写,同时也易于机器解析和...

    JSON入门--WORD文档

    5. JSON不区分大小写,但为了代码的可读性,通常遵循驼峰命名规则。 了解了这些基本概念后,你可以通过实践操作,比如编写一个简单的服务器,返回JSON数据,然后在客户端使用JavaScript解析并显示这些数据,以加深...

    JSON教程_JSON入门

    ### JSON教程:从入门到实践 #### 一、JSON简介 JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,被广泛应用于Web应用程序中进行数据传输。它不仅容易被人阅读和编写,同时也便于计算机解析和生成...

    hessian入门小例子

    这个“Hessian入门小例子”是帮助开发者理解如何在实际项目中应用Hessian的一种方式。下面我们将深入探讨Hessian协议、它的特点、以及如何在Java环境中设置和使用Hessian服务和客户端。 首先,让我们了解Hessian的...

    JSON入门Java篇-5-用JavaBean来构建JSON.rar

    例子如下: ```java import com.fasterxml.jackson.databind.ObjectMapper; public class User { // ... (User类的定义) public static void main(String[] args) { User user = new User(); user.setName(...

    JSON入门(纯文本的数据格式)

    在这个例子中,`address`是一个内嵌的对象,`hobbies`则是一个包含多个字符串的数组。 在JavaScript中,处理JSON数据非常直观,因为JSON的语法结构与JavaScript对象非常相似。可以通过`JSON.parse()`函数将JSON字符...

    JSON入门例子

    var obj,sid;//全局变量 $(document).ready(function() { //看着DIV的样式(位置 ,高度,) var stock=$("#stock").css("border","1px solid black") .width("150px").css("position","absolute") ...

    简单小例子登录,spirng+struts+Ibatis+xml、json解析

    spirng+struts+Ibatis+xml、json解析

    json入门学习

    ### JSON入门学习:掌握异步应用中的数据交换 在当今高度互联的世界中,异步应用程序已成为互联网技术的核心组成部分。在这些应用中,数据的发送和接收至关重要,而JSON(JavaScript Object Notation)作为一种轻量...

    nodejs+express入门小例子

    这个"nodejs+express入门小例子"将帮助初学者理解这两个工具的核心概念和它们如何协同工作。 首先,Node.js是一个开源、跨平台的JavaScript运行环境,它允许开发者在服务器端执行JavaScript代码。Node.js的非阻塞I/...

    springMVC3.2+Rest+jquery1.9+json实现的入门例子

    入门例子,可以运行,完整的包,具体代码说明可见:【http://wenku.baidu.com/view/0ab26ef4f705cc175527096b?fr=prin】,一样的。代码虽然不大,但可运行,有一定的启发性。

    node js开发入门小例子

    这个入门例子涵盖了Node.js的基本用法,包括安装、模块管理和基本的HTTP服务器创建。随着对Node.js的深入学习,可以了解更多的模块,如路由处理、中间件、数据库操作等,从而构建更复杂的Web应用。同时,Node.js的...

    JSON-LIB快速入门(转)

    JSON-LIB快速入门指南 JSON(JavaScript Object Notation)是一种轻量级的数据交换格式,它易于人阅读和编写,同时也易于机器解析和生成。JSON-LIB是一个Java库,用于将Java对象转换为JSON格式,反之亦然。这篇文章...

    getJson+ashx实现数据交互(入门级)

    在这个例子中,`Handler.ashx`是服务器端的处理程序,它负责生成或处理数据并以JSON格式返回。`getJSON`会发送一个HTTP GET请求到指定的URL,并在接收到响应后执行回调函数,其中`data`参数是解析后的JSON数据。 接...

    Extjs4.1 小例子(适合extjs初学者学习使用)

    标题中的"Extjs4.1 小例子"意味着这个压缩包包含了一些基础的示例代码,旨在帮助初学者快速入门。通过这些小例子,你可以了解如何使用ExtJS 4.1来创建用户界面,包括布局管理、组件系统、数据绑定、事件处理等核心...

    Spring MVC入门小例子

    **Spring MVC 入门教程** Spring MVC 是 Spring 框架的一个模块,专门用于构建 Web 应用程序。它提供了一种模型-视图-控制器(MVC)架构,简化了开发过程,使得开发者可以专注于业务逻辑而不必过于关注底层细节。在...

Global site tag (gtag.js) - Google Analytics