JS的jsonp是什么?5分钟学会jsonp跨域请求

一、jsonp是什么?

jsonp是解决跨域请求的一种技术。浏览器为了防止CSRF攻击会采用同源策略(协议/主机/端口均相同)限制,对非同源发起http请求(即跨域请求)会被浏览器阻止。

 

二、jsonp跨域请求的原理?

script标签的src属性不受同源策略限制,用此方式对非同源服务器请求资源,返回的JS代码会调用指定的函数,携带的参数就是所需的数据,这样就完成了跨域请求。

 

三、原生JS的jsonp跨域请求:

首先声明一个处理返回数据的函数,返回的JS代码会调用此函数:
function dosomething(data) {
    console.log(data)
}

然后创建script标签添加到页面,src设为请求地址,请求地址的参数规定了返回的函数名:

<script src="http://example.com/data.php?callback=dosomething"></script>

最后服务端会返回一段JS代码,它会调用指定的函数,携带的参数就是所需的数据,至此跨域请求就完成了。

dosomething({name:"逐逸"});

 

四、jQuery的jsonp跨域请求:

这里的success就跟上面的dosomething一样。

$.ajax({
  url: "http://example.com/data.php",
  type: "GET",
  dataType: "jsonp", //指定服务器返回的数据类型
  success: function(data) {
    console.log(data)
  }
});

 

五、jsonp的优点与缺点:

优点:它不被同源策略限制,而且兼容性更好,在古董浏览器中都可以运行。
缺点:它只支持 GET 请求,而不支持 POST 等其他类型的 HTTP 请求。 

转载于:https://www.cnblogs.com/joych3n/p/10658233.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值