关于JSON与JSONP简单总结
2013-07-25 22:05
260 查看
参考资料:稍后整理
JSONP
定义:是一种跨域数据访问方式。
作用与原理:在客户端声明 callback回调函数之后,客户端通过script标签向服务器跨域请求数据,然后服务端返回相应的JSON数据并动态执行回调函数。
在jQuery中使用如下:
调用 webservices 使用如下:
服务器端(webservices 后台代码):
总结JSONP:
两点需注意:
1.不提供错误处理机制,有数据返回,没有不显示内容,获得一个404的错误
2.如果使用了不信任的服务会造成很大的安全隐患。
JSON
与XML相比,JSON是一个轻量级的数据交换格式。易于人阅读和编写。同时也易于机器解析和生成,分两种:对象(使用下面点语法获取属性值)和数组(遍历数组,索引获取)。
1.把 JSON 文本转换为 JavaScript 对象
从 web 服务器上读取 JSON 数据,将 JSON 数据转换为 JavaScript 对象,然后在网页中使用该数据.
JavaScript 函数 eval() 可用于将 JSON 文本转换为 JavaScript 对象。必须把文本包围在括号中,这样才能避免语法错误。
即:通过eval函数将json串转换为json对象,然后可以通过两种方法访问:
2. 数组 获取
packJson = [
{"name":"nikita", "password":"1111"},
{"name":"tony", "password":"2222"}
];
循环遍历:
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)
/article/5424338.html
后记:总结比较好的文章(20130724)
http://www.cnblogs.com/dowinning/archive/2012/04/19/2458624.html
JSONP
定义:是一种跨域数据访问方式。
作用与原理:在客户端声明 callback回调函数之后,客户端通过script标签向服务器跨域请求数据,然后服务端返回相应的JSON数据并动态执行回调函数。
在jQuery中使用如下:
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 使用如下:
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 后台代码):
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)
/article/5424338.html
后记:总结比较好的文章(20130724)
http://www.cnblogs.com/dowinning/archive/2012/04/19/2458624.html
相关文章推荐
- 关于JSON与JSONP简单总结
- 关于JSON与JSONP简单总结
- 关于JS与OC交互的简单总结
- 关于AOP的学习过程简单总结
- 关于ASP.NET MVC4 Web API简单总结
- 关于json库的简单介绍
- 关于fastjson解析对象和json串互转时空属性值不显示,简单mark一下
- 关于js中 json对象和json字符串的总结
- 关于android和服务器之间的json数据传输总结
- 关于开发个简单应用(账号管家)的总结
- saltstack一些简单总结--关于salt-key命令的一些(3)
- 关于mysql 简单的查询语句 以及常用函数的 总结
- 简单描述JSON跟JSONP的区别以及实战
- 关于json的一点总结
- 关于mysql 简单的查询语句 以及常用函数的 总结
- 关于Windows高DPI的一些简单总结
- 关于以前的简单总结
- 关于xml和Json数据解析的一些总结
- 关于JSON的一些总结
- 关于学习json的总结