最新下载
热门教程
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
PHP下ajax跨域的解决方案之jsonp代码实例分析
时间:2022-06-24 22:22:49 编辑:袖梨 来源:一聚教程网
本篇文章小编给大家分享一下PHP下ajax跨域的解决方案之jsonp代码实例分析,小编觉得挺不错的,现在分享给大家供大家参考,有需要的小伙伴们可以来看看。
首先要说明一下json和jsonp的区别?
json是一种基于文本的数据交换方式,或者叫做描述数据的一种格式。
var person = { "name": "test", "age": "25", "sex": "男" }; var data = [1, 2, 3, 4, 5];
而jsonp是一种非官方跨域数据交互协议,该协议允许用户传递一个callback参数给服务端,然后服务端返回数据时会将这个callback参数作为函数名来包裹住json数据,这样客户端就可以随意定制自己的函数来自动处理返回数据了。
比如我在a.com的网站上引用了b.com的一个b.js,但这样跨域的引用并不会产生错误,说明调用js文件时不受跨域的影响。
那么我们在b.js里添加如下代码,看看是否能够执行
alert("I from b");
确定是可以执行。
那么如果我们在a.com上自已创建一个js函数,而在b.com下的b.js中调用,那是否可行呢?
a.com下的index.html如下:
b.com下的b.js如下:
a("from b");
上面也是可以执行的,我们可以看到在b.js中的数据确实正确的传到了函数a中。
问题又来了,a.com中创建的函数名与b.js中调用的函数名必须一致,那么如何才能让b.com服务端知道这个函数名,只有通过地址栏来传递了,加上一个callback=函数名来传递。当然callback这个命名可以改,但大家都这么命名,也就约定俗成了。
a.com下的index.html如下:
b.com下的b.php如下:
1, 'name' => '测试', )); echo "{$callback}({$data});"; }
上面也是可以执行的,知道了回调函数名,b.com服务端处理好数据,然后通过字符串拼接输出。
jquery中就已经提供了jsonp的支持,a.com下的index.html如下所示:
跨域策略限制情况表如下:
相关文章
- 二重螺旋魔灵怎么突破 魔灵突破方法 09-19
- 阴阳师魂13阵容虚无大蛇怎么配队-魂13阵容虚无大蛇搭配推荐 09-19
- 对决剑之川诸葛玲珑怎么配队 诸葛玲珑配队攻略 09-19
- 零度曙光盾锤技能怎么搭配 盾锤技能搭配推荐 09-19
- 失控进化建家位置怎么选 建家位置选择推荐 09-19
- 对决剑之川曲玉怎么样 曲玉角色介绍 09-19