同源策略 及 jsonp

同源是指两个站点同协议,同端口,同域名。

同源策略规定:不同域的客户端脚本在没有明确授权的情况下,不能读写对方资源。


但是,在数据传输过程中,经常会发生跨域的数据交换,那么如何解决这个问题呢。。就利用到了一些支持跨域传输的标签(比如<script>、<img>等)

   <script type = "text/javascript" src = "http://www.pp.com/alert.js"></script>

既然他可以跨域传输,那么如果引用的"www.pp.com/alert.js"中有

  test();

  kuayu();

那么,它执行的顺序就是,先执行test(),在执行kuayu();

这是,如果你自己的页面有个函数

  function kuayu(){

    alert("lalala");

}

那么因为是引用进来的。然后他走test(),然后执行kuayu(),所以就弹出lalala!了。

如果这个方法有形参的话,那么,这个形参就可以了当做载体,来传递我们想传递的值了!

function kuayu(json){
     alert("我获取到了 跨域值"+  json  );
      }
-----------------------
pp.com/alert.js    .....
.....
....
kuayu("我是数据,我想跨域,在那边看到我了吗?");
-----------------------------------------------------------
最终输出  我获取到了跨域值, 我是数据,我想跨域,在那边看到我了吗?
ok,以上就是其的基本思想
那么,什么jsonp呢?jsonp就是一种为了解决跨域的数据交换而衍生出来的一种协议。jsonp只可实现get的传输方式。

(jsonp和json就像周杰和周杰伦一样,没有半毛钱关系!!)

原理说完了,接下来上代码!!

var ajaxUrl = "http://192.168.8.141:9092/project/rest/team/matchResult/1/20/1/1000";


function localHandler(data) {
console.log("fengshu")
console.log(data);
}

var ajaxParam = {
async: false,
url: ajaxUrl, 
type: "GET",
dataType: 'jsonp',//非正式跨域传输协议
jsonp: 'localHandler',
success: function (json) {
//回调数据在localHandler处理
}
};
$.ajax(ajaxParam);


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值