jQuery jsonp跨域原理

实际上单jQuery还是实现不了跨域加载数据的,由于XMLHttpRequest的安全设置,是不允许直接跨域的。jQuery的jsonp虽然能跨域,但是还得请求的页面支持才行,如果请求的页面不理会jQuery发送的参数,是无法跨域的,实际上来说是获取不到输出的页面内容。

  jQuery jsonp跨域原理实际就是使用script标签加载配置对象中的跨域url,再使用script标签加载之前,会在客户端中注册一个新的函数作为回调函数提供给跨域页面使用,然后将函数名称替换掉url中jsoncallback=?后面的问号,最后请求的页面获取发送的回调函数名称,输出类似“回调函数名称(json数据)”的JavaScript代码来执行回调函数,参数为json数据。和代理意义差不多,jsonp需要代理页面输出执行回调函数的js代码。

  通过jQuery的跨域原来我们知道,如果跨域页面不理会回调函数,不执行它,那么就无法获取到跨域页面输出的json函数,甚至可能会出现脚本错误,因为是使用script来加载跨域页面。
  
  下面是一个jQuery jsonp跨域调用

test.html
-HTML
<script type="text/javascript" src="jquery-1.4.2.min.js"> </script> 
<script type="text/javascript">
$.getJSON( '//json.asp?jsoncallback=?', //请求另外一个跨跨域的页面
function(data){
 alert(data.name)
}); </script>

  上面的代码中,实际请求的页面类似//json.asp?jsoncallback=jsonp1279531004015,后面一长串的数字为jQuery动态加上的。

json.asp
-VBScript

'输出js脚本执行jQuery注册回调函数,参数为json对象
'如果我们不理会jq发送的回调函数名称,而是直接输出json数据,这样是获取不到json数据的
response.write request.querystring( "jsoncallback")& "({name:'showbo'})"

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值