JSON使用

是什么?

       JSON(JavaScript Object Notation)是以一种对象方式操作Javascript的技术,它是建立在W3C标准之上的,并且不依赖于特定语言。它提供了简便的表示对象的方式,具体体现为下面两种数据结构:

Map:提供了KEY/VALUE形式表示对象的属性和值,对象间的属性是无序的;
Array :提供了有序的集合。
简单来说,JSON中只使用两种符号:

{}大括号:表示一个对象的界限,其中包括用逗号分隔的多个键值对(属性名:属性值);
[]方括号: 作为对象数组形式属性的界限,其中包括多个用逗号隔开的值(也可以是复杂结构的值)。
说明:

对象是属性、值对的集合。一个对象的开始于“{”,结束于“}”。每一个属性名和值间用“:”提示,属性间用“,”分隔。
数组是有顺序的值的集合。一个数组开始于"[",结束于"]",值之间用","分隔。
值可以是引号里的字符串、数字、true、false、null,也可以是对象或数组。这些结构都能嵌套。
字符串和数字的定义和C或Java基本一致。
基本应用?

下面的例子表示了一个学生对象:

var student = {
    "id": 123,
     "name": {“firstName”:"haha","lastName":"heihei"},
     "phone": ["12348466789", "02912345678"],
     "addr":"paris"
} 

 

我们便可以用student.id、student.phone[0]、student.name.firstName(student['name']['firstName'])的方式引用student的属性。

Java语言中的应用?

(注:下面的示例默认我们已经下载了json.js和JSON针对JAVA语言的实现代码)
1、页面的使用:
json.js中提供了JSON对象,它主要包括两个函数,用于JSON字符串和对象间的转换:

var o = JSON.parse(jsonStr);//将JSON字符串转化成Javascript对象
var s = JSON.stringify(obj); //将Javascript对象转化成JSON字符串

 

以下是页面 实际使用的例子(部分):

<html>
<head><title>TEST JSON</title>
<script type="text/javascript" src="json.js"></script>
<script type="text/javascript">
var xmlHttp;
function createXMLHttpRequest(){
if(window.ActiveXObject){
   xmlHttp = new ActiveXObject("Microsoft.XMLHttp");
}else if(window.XMLHttpRequest){
   xmlHttp = new XMLHttpRequest();
}
}

function hello(){
var car = getCarObject();
var carAsJSON = JSON.stringify(car);
//alert("Car object as JSON:\n" + carAsJSON);
var url = "JSONExample1?timestamp=" + new Date().getTime();
createXMLHttpRequest();
xmlHttp.open("POST", url, true);
xmlHttp.onreadystatechange = handleStateChange;
xmlHttp.setRequestHeader("Content-Type", "application/x-www-form-urlencoded;");
xmlHttp.send(carAsJSON);
}

function handleStateChange(){
if(xmlHttp.readyState == 4){
   if(xmlHttp.status == 200){
    parseResults();
   }
}
}


function parseResults(){
var responseDiv = document.getElementById("serverResponse");
if(responseDiv.hasChildNodes()){
   responseDiv.removeChild(responseDiv.childNodes[0]);
}

var responseText = document.createTextNode(xmlHttp.responseText);
responseDiv.appendChild(responseText);
var c = document.getElementById("c");
c.color = getCarObject().color;

}

function getCarObject(){
var make = document.getElementsByName("make");
var selectMake;
for(var i = 0; i < make.length; i++){
   if(make[i].checked){
    selectMake = make[i].value;
   }
}

var color = document.getElementsByName("color");
var selectColor;
for(var i = 0; i < color.length; i++){
   if(color[i].checked){
    selectColor = color[i].value;
   }
}

return new Car(selectMake, selectColor);

}

function Car(make, color){
this.make = make;//品牌
this.color = color;//颜色
}
</script>
</head>

<body bgcolor="lightblue">
<br/>
<h2>疯狂购车</h2>
<form action="#">
请选择车的品牌:
<input type="radio" name="make" checked="true" value="AUDIO" onclick="hello();">奥迪
<input type="radio" name="make" value="BENZ" onclick="hello();">奔驰
<input type="radio" name="make" value="BMW" onclick="hello();">宝马
<input type="radio" name="make" value="TOYOTA" onclick="hello();">丰田
<br/>

请选择车的颜色:
<input type="radio" name="color" checked="true" value="BLACK" onclick="hello();">黑色
<input type="radio" name="color" value="GREEN" onclick="hello();">绿色
<input type="radio" name="color" value="RED" onclick="hello();">红色
<input type="radio" name="color" value="BLUE" onclick="hello();">蓝色
<br/><br/>
</form>

<font id="c" color="black"><b><div id="serverResponse"></div></b></font>
</body>
</html>

 


2、服务器端代码中的使用:

import java.io.BufferedReader;
import java.io.IOException;

import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import org.json.JSONException;
import org.json.JSONObject;

public class JSONExample1 extends HttpServlet{

public void doPost(HttpServletRequest request, HttpServletResponse response) 
   throws IOException, ServletException {

   request.setCharacterEncoding("UTF-8");

   String json = readJSONStringFromRequestBody(request);
   System.out.println("========" + json);

   JSONObject jsonObject = null;
   try{
    jsonObject = new JSONObject(json);
   }catch(JSONException e){
    System.out.println("JSONException");
    e.printStackTrace();
   }

   String car = "";
   String color = "";
   try {
    car = jsonObject.getString("make");
    color = jsonObject.getString("color");
   } catch (JSONException e1) {
    System.out.println("JSONException");
    e1.printStackTrace();
   }

   String fCar = "奥迪";
   String fColor = "黑色";

   if("AUDIO".equalsIgnoreCase(car)){
    fCar = "奥迪";
   }else if("BENZ".equalsIgnoreCase(car)){
    fCar = "奔驰";
   }else if("BMW".equalsIgnoreCase(car)){
    fCar = "宝马";
   }else if("TOYOTA".equalsIgnoreCase(car)){
    fCar = "丰田";
   }

   if("BLACK".equalsIgnoreCase(color)){
    fColor = "黑色";
   }else if("RED".equalsIgnoreCase(color)){
    fColor = "红色";
   }else if("GREEN".equalsIgnoreCase(color)){
    fColor = "绿色";
   }else if("BLUE".equalsIgnoreCase(color)){
    fColor = "蓝色";
   }

   String responseText = " 恭喜您拥有了一辆" 
    + fColor + fCar + ".";
   response.setContentType("text/html;charset=UTF-8");
   response.getWriter().print(responseText);
}

private String readJSONStringFromRequestBody(HttpServletRequest request) {

   StringBuffer json = new StringBuffer();
   String line = null;
   try {
    BufferedReader reader = request.getReader();
    while((line = reader.readLine()) != null){
     json.append(line);
    }
   } catch (IOException e) {
    System.out.println("IOException");
    e.printStackTrace();
   }
   return json.toString();
} 
}

 

 

应用前景:

Web数据传递,像Ajax应用中的数据传递,例如在ExtJS中的HttpProxy利用JSON字符串格式传递数据。

参考资源

官方网站:http://www.json.org

使用 JSON 进行数据传输:http://www.ibm.com/developerworks/cn/web/wa-ajaxintro10/

 

 

补充(2008-10-16)

在上面的例子中我们使用了json.org提供的Jar包,它的操作不够优雅,我们又找到了json-lib,它的使用转载如下:

(转自:http://blog.csdn.net/jawsy/archive/2007/04/09/1557165.aspx)

 

下载

    到http://json-lib.sourceforge.net下载json-lib-1.1-jdk15.jar,运行json还需要的包有:commons-lang.jar、commons-logging.jar,commons-beanutils.jar、

xom-1.0-2005-01-05.jar、ezmorph-1.0.1.jar,可在http://www.docjar.com搜索下载。

  

 转化数组和集合

boolean[] boolArray = new boolean[]{true,false,true};
JSONArray jsonArray = JSONArray.fromObject(boolArray);
System.out.println(jsonArray);


    输出:[true,false,true]

List list = new ArrayList();
list.add(“第一个”);
list.add(“第二个”);
JSONArray jsonArray = JSONArray.fromObject(list);
System.out.println(jsonArray);

 
    输出:[“第一个”, “第二个”]

JSONArray jsonArray3 = JSONArray.fromObject("['json','is','easy']");
System.out.println(jsonArray3);


    输出:[“json”, “is”, “'easy'”]

 
 转化Map

Map map = new HashMap();
map.put("name","json");
map.put("bool",Boolean.TRUE);
map.put("int",new Integer(1));
map.put("arr",new String[]{"a","b"});
map.put("func","function(i){return this.arr[i];}"); 

JSONObject json = JSONObject.fromObject(map);
System.out.println(json);


   输出:[“name”: “json”, “bool”:true, “int”,1, “arr”:[ “a”, “b”], “func”:function(i){return this.arr[i];}]
 

转化Bean

//MyBean.java

public class MyBean {
    private String name = "json";
    private int pojoId = 1;
    private String func1 = "function(i){return this.options[i]}";
    private JSONFunction func2 = 
          new JSONFunction(new String[]{"i"},"return this.options[i];");

    //以下为get、set方法

} 

MyBean bean = new MyBean();
JSONObject jsonObject = JSONObject.fromObject(bean);
System.out.println(jsonObject);

 

    输出:{"func1":function(i){return this.options[i]},"pojoId":1,"name":"json","func2":function(i){ return this.options[i]; }


从JSON到Beans

//转化为动态bean

String myjson = "{name=\"json\",bool:true,int:1,double:2.2,function:function(a){return a;},array:[1,2]}";

JSONObject json1 = JSONObject.fromString(myjson);

Object bean1 = JSONObject.toBean(json1);

 
由JSON生成XML

JSONObject json = new JSONObject(true);
XMLSerializer xmlSerializer = new XMLSerializer();

String xml = xmlSerializer.write(json);
System.out.println("xml:" + xml);


    输出xml:

 

<?xml version="1.0" encoding="UTF-8"?>
<o null="true"/>

 

JSONObject json2 = JSONObject.fromObject("{\"name\":\"json\",\"bool\":true,\"int\":1}");
String xml2 = xmlSerializer.write(json2);

System.out.println("xml2:" + xml2);
 

    输出xml2:

 

<?xml version="1.0" encoding="UTF-8"?>
<o>
    <bool type="boolean">true</bool>
    <int type="number">1</int>
    <name type="string">json</name>
</o>

 

 

JSONArray json3 = JSONArray.fromObject("[1,2,3]");
String xml3 = xmlSerializer.write(json3);

System.out.println("xml3:" + xml3);
 

    输出xml3:

 

<?xml version="1.0" encoding="UTF-8"?>
<a>
   <e type="number">1</e>
   <e type="number">2</e>
   <e type="number">3</e>
</a>

你可能感兴趣的:(JavaScript,xml,bean,json,servlet)