jquery:利用jsonp解决跨域访问
jQuery #jsonp #跨域2012-04-25 13:07
参考文档:http://www.ibm.com/developerworks/cn/web/wa-aj-jsonp1/
注意:jquey是不支持post方式跨域的。
客户端的跨域访问,可以通过jsonp方式来实现,jquery提供了跨域访问的方法,jQuery.ajax()支持get方式的跨域。当然支持跨域还需要服务器端相应的处理。
01 | $.ajax({ |
02 | async: false , |
03 | url: '' , // 跨域URL |
04 | type: 'GET' , |
05 | dataType: 'jsonp' , |
06 | jsonp: 'jsoncallback' , //默认callback |
07 | data: mydata, //请求数据 |
08 | timeout: 5000, |
09 | beforeSend: function (){ //jsonp 方式此方法不被触发。原因可能是dataType如果指定为jsonp的话,就已经不是ajax事件了 |
10 | }, |
11 | success: function (json) { //客户端jquery预先定义好的callback函数,成功获取跨域服务器上的json数据后,会动态执行这个callback函数 |
12 | if (json.actionErrors.length!=0){ |
13 | alert(json.actionErrors); |
14 | } |
15 | |
16 | }, |
17 | complete: function (XMLHttpRequest, textStatus){ |
18 | |
19 | }, |
20 | error: function (xhr){ |
21 | //jsonp 方式此方法不被触发 |
22 | //请求出错处理 |
23 | alert( "请求出错(请检查相关度网络状况.)" ); |
24 | } |
25 | }); |
1 | $.getJSON(url+ "?callback=?" , |
2 | function (json){ |
3 | |
4 | }); |
在服务端通过获得callback参数(如:jsonp*****)得到jQuery端随后要回调的
然后返回类似:"jsonp*****("+要返回的json数组+")";
jquery就会通过回调方法动态加载调用这个:jsonp*****(json数组);
这样就达到了跨域数据交换的目的.
JSONP是一种脚本注入(Script Injection)行为,所以也有一定的安全隐患。