关于Jsonp跨域原理详解及简单应用

关于Jsonp跨域原理详解及简单应用

浏览器的同源策略:

同源策略(Same Origin Policy)是一种约定,它是由Netscape提出的一个著名的安全策略,它限制了从同一个源加载的文档或脚本如何与来自另一个源的资源进行交互。这是一个用于隔离潜在恶意文件的重要安全机制。

同源的定义:如果两个页面的协议,端口(如果有指定)和主机都相同,则两个页面具有相同的源。我们也可以把它称为“协议/主机/端口 tuple”,或简单地叫做“tuple”. (“tuple” ,“元”,是指一些事物组合在一起形成一个整体,比如(1,2)叫二元,(1,2,3)叫三元)

如果协议、端口、主机(域名或IP地址,如果是IP地址则看做一个根域名)、子域名,当其中一个不同,则我们的请求即会发生跨域问题。

下表给出了相对http://store.company.com/dir/page.html同源检测的示例: 

de454bb06807938af2d97ee1d4557fe.png

 

 

 

 

 

 

 

 

 

 

突破同源策略限制:

1、script标签的src/img标签的src,或者说link标签的href他们没有被通源策略所限制

2、src或href链接的静态资源,本质上来说也是一个get请求

JSONP是什么?和json有关系吗?

Json(JavaScript Object Notation) 是一种轻量级的数据交换格式。

JSONP是JSON with Padding的略称。它是一个非官方非正式的传输的协议,它允许在服务器端集成Script tags返回至客户端,通过javascript callback的形式实现跨域访问。

JSONP的简单实现:

html代码:(运行在本地http://zrcloud.com/test.html)

 

nbsp;html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">Jsonp简单实例

JSONP简单实例

$(function() { $.ajax({ type:'get', async:false,//同步请求 url:'http://mqcms.com/test.php', dataType:'jsonp', jsonp:'callback',//传递给请求处理程序或页面的,用以获得jsonp回调函数名的参数名(一般默认为:callback) jsonpCallback:'test',//自定义的jsonp回调函数名称,默认为jQuery自动生成的随机函数名,也可以写"?",jQuery会自动为你处理数据 success:function(data){ console.log(data); } }) })

登录后复制

 

PHP服务器端代码:

'test','age'=>18,'sex'=>1];echo $callback.'('.json_encode($arr).')';?>

登录后复制

运行结果: 

eaa3cee9f02b4c41c8745bee99c1df6.png

 注:为什么我这次没有写test这个函数呢?而且竟然也运行成功了!

这就是jQuery的功劳了,jquery在处理jsonp类型的ajax时(,虽然jquery也把jsonp归入了ajax,但其实它们真的不是一回事儿),自动帮你生成回调函数并把数据取出来供success属性方法来调用。

以上就是关于Jsonp跨域原理详解及简单应用的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2729237.html

(0)
上一篇 2025年3月8日 00:05:05
下一篇 2025年3月1日 05:59:37

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • JSONP原理是什么?

    JSONP原理:首先在客户端注册一个函数;然后把函数的名字传给服务器;接着服务器成JSON数据,并以Javascript语法的方式,将数据传入客户端注册的函数中;最后在客户端注册函数中接收JSON即可。 JSONP JSONP(JSON w…

    2025年3月7日
    200
  • 详解JS中的JSON和JSONP

    简单地使用json并不能支持跨域资源请求,为了解决这个问题,需要采用jsonp数据交互协议。众所周知,js文件的调用不受跨域与否的限制,因此如果想通过纯web端跨域访问数据,只能在远程服务器上设法将json数据封装进js格式的文件中,供客户…

    2025年3月7日
    200
  • PHP通信:如何实现跨域数据传输?

    PHP通信:如何实现跨域数据传输? 引言:在网页开发中,常常需要实现不同域名之间的数据传输,这就需要跨域通信。本文将介绍使用PHP语言实现跨域数据传输的方法,并附上代码示例。 一、什么是跨域通信?跨域通信指的是在网页开发中,不同域名间进行数…

    2025年2月21日
    200

发表回复

登录后才能评论