码迷,mamicode.com
首页 > Web开发 > 详细

JSONP 的工作原理是什么?

时间:2017-01-14 18:19:41      阅读:285      评论:0      收藏:0      [点我收藏+]

标签:json   对象   规范   gen   调用   padding   处理   add   产生   

很简单,就是利用<script>标签没有跨域限制的“漏洞”(历史遗迹啊)来达到与第三方通讯的目的。当需要通讯时,本站脚本创建一个<script>元素,地址指向第三方的API网址,形如:
<script src="http://www.example.net/api?param1=1&param2=2"></script>
并提供一个回调函数来接收数据(函数名可约定,或通过地址参数传递)。
第三方产生的响应为json数据的包装(故称之为jsonp,即json padding),形如:
callback({"name":"hax","gender":"Male"})
这样浏览器会调用callback函数,并传递解析后json对象作为参数。本站脚本可在callback函数里处理所传入的数据。
补充:“历史遗迹”的意思就是,如果在今天重新设计的话,也许就不会允许这样简单的跨域了嘿,比如可能像XHR一样按照CORS规范要求服务器发送特定的http头。



 
 

JSONP 的工作原理是什么?

标签:json   对象   规范   gen   调用   padding   处理   add   产生   

原文地址:http://www.cnblogs.com/aishangliming/p/6285746.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!