jsonp实现原理解析

PHP中文网
PHP中文网 原创
2017-06-21 13:29:52 6374浏览

一. jsonp实现原理是利用script标签可以获取不同源资源的特点,来达到跨域访问某个资源的目的。具体行为如下:

  1. 创建一个script标签,将请求地址写入它的src属性,将这个script外链插入head标签中;

  2. 声明一个回调函数callback,函数名和请求地址中的一致;

  3. 请求地址的内容是一个以json对象为参数的执行函数callback;

  4. 当script资源载入时,callback开始执行,将json数据输出。

  5. jsonp其实就是json padding,而在json数据外包裹它的那个函数,就是padding。

// 简单的mock jsonpvar mockJsonp = function(url) {var ele = document.createElement('script');var head = document.getElementsByTagName('head')[0];
    ele.src = url;
    head.appendChild(ele);
}
mockJsonp('./index.js');function callback(data){
    console.log(data);
}// index.jscallback("name": "xxx", "age": "20");

二. jq中的ajax请求数据格式为jsonp时,会发生以下操作:先构造一个script标签,然后注册一个onload的回调,最后将构造好的script标签insert进去;insert完成之后,会触发onload回调,其中又将前面插入的script标签去掉了。其中的 代码 callback( 200, "success" ) 其实就是触发 ajax 的jsonp成功时的success回调函数,callback函数其实是一个 done 函数。

三. jsonp跨域只能是get请求,jq在封装jsonp跨域时,不论我们指定的是get还是post,他统一换成了get请求。

四. 其他跨域方式

  1. cors(Cross-Origin Resource Sharing)跨域资源共享,服务器端设置Access-Control-Allow-Origin,如果浏览器检测到相应的设置,就会允许访问;

  2. 修改document.domain,将子域和主域的document.domain设为同一个主域;

  3. window.name,每个页面都对window.name有读写的权限,window.name持久存在在一个窗口载入过的所有页面中;

  4. window.postMessage

以上就是 jsonp实现原理解析的详细内容,更多请关注php中文网其它相关文章!

声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。