JSONP跨域原理浅析

JSONP的出现是因为浏览器的同源策略,同源是指所请求的域名、协议、端口号和当前请求相同,同源策略限制了原生XMLHttpRequest()对象无法获取到JSON数据,但是<script><img><link>标签是可以跨域的。


JSONP的原理是通过<script>标签向服务器发送请求,将前端方法作为参数传递到服务器,服务器接收到请求后将SON数据作为该方法的参数,返回JavaScript文本,前端方法就可以拿到数据。

JSONP的请求过程:

  • 请求阶段:浏览器创建一个 script 标签,并给其src 赋值。

  • 发送请求:当给script的src赋值时,浏览器就会发起一个请求。

  • 数据响应:服务端将要返回的数据作为参数和函数名称拼接在一起(格式类似”jsonpCallback({name: 'abc'})”)返回。当浏览器接收到了响应数据,由于发起请求的是 script,所以相当于直接调用 jsonpCallback 方法,并且传入了一个参数。




注:由于使用的是script标签的src属性,所以只支持get方法



服务器返回数据
callback([
  {
    "logo":"img-1.png",
    "title":"标题1"
  },
  {
    "logo":"img-2.png",
    "title":"标题2"
  },
  {
    "logo":"img-3.png",
    "title":"标题3"
  },
  {
    "logo":"img-4.png",
    "title":"标题4"
  }
])


原生JS实现方式
function jsonp(req){
     var script = document.createElement("script");
    script.setAttribute("src", req.url+"?param="+req.callback.name);
    document.body.appendChild(script);
 }
function callback(res){
     console.log(res);
}
jsonp({
     url: '',
     callback: callback
})


JQuery实现方式
function callback(res){
     console.log(res);
}
 $.ajax({
      url: '',
      type: 'GET',
      dataType:'jsonp',
      jsonp:'callback',
      jsonpCallback:'callback',
      success: function (res) {
       console.log(res);
      }
    });




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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值