JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式。易于人阅读和编写。同时也易于机器解析和生成。它基于JavaScript Programming Language, Standard ECMA-262 3rd Edition - December 1999的一个子集。 JSON采用完全独立于语言的文本格式,但是也使用了类似于C语言家族的习惯(包括C, C++, C#, Java, JavaScript, Perl, Python等)。这些特性使JSON成为理想的数据交换语言。
JSON建构于两种结构:
- “名称/值”对的集合(A collection of name/value pairs)。不同的语言中,它被理解为对象(object),纪录(record),结构(struct),字典(dictionary),哈希表(hash table),有键列表(keyed list),或者关联数组 (associative array)。
- 值的有序列表(An ordered list of values)。在大部分语言中,它被理解为数组(array)。
- 这些都是常见的数据结构。事实上大部分现代计算机语言都以某种形式支持它们。这使得一种数据格式在同样基于这些结构的编程语言之间交换成为可能
JSON具有以下这些形式:
1、对象是一个无序的“‘名称/值’对”集合。一个对象以“{”(左括号)开始,“}”(右括号)结束。每个“名称”后跟一个“:”(冒号);“‘名称/值’ 对”之间使用“,”(逗号)分隔。
例如定义一个人的对象:{name:"xiaoming","sex":"male","age":18}
2、数组是值(value)的有序集合。一个数组以“[”(左中括号)开始,“]”(右中括号)结束。值之间使用“,”(逗号)分隔。
例如:[1,2,3,4,5] ["name","hello","world",4,5,6]
3、值(value)可以是双引号括起来的字符串(string)、数值(number)、true
、false
、
null
、对象(object)或者数组(array)。这些结构可以嵌套。
例如:"welcome to china","2"
4、字符串(string)是由双引号包围的任意数量Unicode字符的集合,使用反斜线转义。一个字符(character)即一个单独的字符串(character string)。
JSON具有以下这些形式:”(引号)、b(空格)、n(新行)、f(换页)、r(回车)、t(水平定位)、u(为Unicode字符增加4个数位)、(反斜线符号)、/(正斜杠符号)。
字符串(string)与C或者Java的字符串非常相似。
5、
数值(number)也与C或者Java的数值非常相似。除去未曾使用的八进制与十六进制格式。除去一些编码细节,空白可以加入到任何符号之间。
以上摘自:http://www.json.org/json-zh.html
下面是一些常见的json数据的定义:
定义一个简单的对象:var user={ "Id" :1, "Name" : "Hubery" , "Age" :23, "Email" : "hubery@163.com" };
取出数据:user.id,user.Name...
对象里面包含对象:
{ "Id" :1, "Name" : "Hubery" , "Age" :23, "Email" : "hubery@163.com" ,"address":{"city":"changsha","street","no2"}}
取出数据:user.Name,user.address.city
如果一个人有多个地址,我们可以用数组表示:
{"name":"tom","age":"13","address":[{"city":"changsha","street","no2"},{"city":"beijing","street","no5"}]}
取出数据:user.age,user.address[0].street
我们还可以用数组定义多个用户:
[{"name":"tom","age":"13","address":[{"city":"changsha","street","no2"},{"city":"beijing","street","no5"}]},
{"name":"tom","age":"13","address":[{"city":"changsha","street","no2"},{"city":"beijing","street","no5"}]},
{"name":"tom","age":"13","address":[{"city":"changsha","street","no2"},{"city":"beijing","street","no5"}]}]
取出数据:user[0].name,user[0].address[0].street
JavaScript中JSON的运用:
例如我们从后台取出的数据需要在js中调用
一旦接受服务器的JSON数据,就可以采用两种不同的方式解析该响应。可以使用JavaScript的内置函数eval(),或者为了进一步的安全,使用JSON解析器代替。
eval()方法可以把JavaScript字符串当作参数,还可以将该字符串转换成对象,或作为命令动作。如果使用XMLHttpRequest对象的
responseText属性请求JSON数据,那么使用eval()将JSON文本字符串转换成JavaScript对象。因为JSON字符串常包包含
花括号,所以用圆括号来括住JSON字符串,以表明字它是一个求值表达式,而不是一个要运行的命令。
var jsonResp=request.responseText;
jsonResp=eval(“(”+jsonResp+”)”);转换为js对象
如果Web服务器既提供JSON数据也提供请求页面,则适合选用eval()方法。如果涉及安全,则适合使用JSON解析器。JSON解析器只作用于
JSON文本,并且不执行其他JavaScript。在这种情况下,可以使用responseText,但要使用parseJSON()方法将JSON文
本字符串转换成JavaScript对象。要访问parseJOSN函数,需要要添加引用json.js文件到页面中。
var jsonResp=request.responseText;
jsonResp=jsonResp.parseJSON();
下面以实例来说明在JavaScript中简单使用JSON:
<script type="text/javascript">
var user =[
{
"name":”shenmiweiyi”,
"QQ":306451129,
"email":”shenmiweiyi@163.com”
"address":
[
{"City":"ZhengZhou","ZipCode":"450000"},
{"City":"BeiJing","ZipCode":"100000"}
]
},
{
"name":”kehao”,
"QQ":254892313,
"email":”kehao@163.com”
"address":
[
{"City":"ShangHai","ZipCode":"200000"},
{"City":"GuangZhou","ZipCode":"510000"}
]
}
]
alert(user[0].name+”的Email是:”user[0].email); //outputs shenmiweiyi的Email是:shenmiweiyi@163.com
alert(user[1].name+”住在:”user[1].address[0].city) //outputs kehao住在:ShangHai
</script>
JSON已经是JavaScript标准的一部分。目前,主流的浏览器对JSON支持都非常完美,应用JSON,我们可以从XML的解析中摆脱出来,对那些应用Ajax的Web2.0网站来说,JSON确实是目前最灵活的轻量级方案。
JSON解析:
java对象与json对象转换:
java对象转为json对象:
List转为json对象:
- import org.json.JSONArray;
- import org.json.JSONException;
- import org.json.JSONObject;
- JSONArray json = new JSONArray();
- try {
- for(int j=0;j<list.size();j++){
- Menu m=(Menu)list.get(j);
- JSONObject jo = new JSONObject();
- jo.put("sysid", m.sysid);
- jo.put("menuName", m.menuName);
- jo.put("parent", m.parent);
- json.put(jo);
- }
- } catch (JSONException e) {
- // TODO Auto-generated catch block
- e.printStackTrace();
- }
- System.out.println(json.toString() );