关于JSON与JSONP简单总结

参考资料:稍后整理

JSONP

定义:是一种跨域数据访问方式。

作用与原理:在客户端声明 callback回调函数之后,客户端通过script标签向服务器跨域请求数据,然后服务端返回相应的JSON数据并动态执行回调函数。

 

在jQuery中使用如下:

 

JQuery Code
1     //JQuery JSONP Support  
2     var url = "http://192.168.0.103:12075/api/test.aspx?id=1&callback=?";  
3     jQuery.getJSON(url, function(data){  
4 // 处理返回的json 数据
5     alert("name:" + data.name+ ", Price:" + data.price);  
6     }); 

 

调用 webservices 使用如下:

 

View Code
1      $.getJSON(  
2      "http://192.168.0.103:12050/services/WebService1.asmx/ws/test?callback=?",  
3      { name: "jim", time: "2pm" },  
4      function(data) {
5  //处理返回的json 数据
6   alert(decodeURI(data.msg));
7  
8   });

 

服务器端(webservices 后台代码):

webservices Code
 1 [WebMethod]  
 2 public void ws(string name,string time) {  
 3 
 4 HttpRequest Request = HttpContext.Current.Request;  
 5 string callback = Request["callback"];  
 6 
 7 HttpResponse Response = HttpContext.Current.Response;  
 8 Response.Write(callback + "({msg:' 返回数据'})");  
 9 
10 Response.End();  
11 }

 

总结JSONP:

两点需注意:

1.不提供错误处理机制,有数据返回,没有不显示内容,获得一个404的错误

2.如果使用了不信任的服务会造成很大的安全隐患。


 

JSON

 与XML相比,JSON是一个轻量级的数据交换格式。易于人阅读和编写。同时也易于机器解析和生成,分两种:对象(使用下面点语法获取属性值)和数组(遍历数组,索引获取)。

1.把 JSON 文本转换为 JavaScript 对象

从 web 服务器上读取 JSON 数据,将 JSON 数据转换为 JavaScript 对象,然后在网页中使用该数据.

JavaScript 函数 eval() 可用于将 JSON 文本转换为 JavaScript 对象。必须把文本包围在括号中,这样才能避免语法错误。

即:通过eval函数将json串转换为json对象,然后可以通过两种方法访问:

服务器端:
// user 实体对象,后台序列化成对象,供前台使用
string strJson = Newtonsoft.Json.JsonConvert.SerializeObject(user);
context.Response.Write(strJson);


前台:
$.getJSON(   
"webdata/test.aspx",
    
function(data) {
//获取对象里面的一个值(username:用户姓名)
       $(
"#divmessage").text(data.username);
    }
);

 2. 数组 获取

packJson = [

{"name":"nikita", "password":"1111"},

{"name":"tony", "password":"2222"}

];

循环遍历:

for(var i = 0; i < packJson.length; i++){

   alert(packJson[i].name + " " + packJson[i].password);

}

tks:

json 与jsonp:http://developer.51cto.com/art/201105/264791.htm

http://www.cnblogs.com/jams742003/archive/2009/12/29/1634764.html

http://www.cnblogs.com/zhangliang0115/archive/2012/08/16/2642138.html

后记:

平时用的比较多的JSON处理方法总结了一下,权当加深记忆(20130409)

http://www.cnblogs.com/victoria/archive/2013/04/09/3009517.html

后记:总结比较好的文章(20130724)

http://www.cnblogs.com/dowinning/archive/2012/04/19/2458624.html

posted @ 2013-01-30 14:20  365lei  阅读(8134)  评论(0编辑  收藏  举报