Rumah >hujung hadapan web >tutorial js > jsonp实现原理解析

jsonp实现原理解析

PHP中文网
PHP中文网asal
2017-06-21 13:29:526872semak imbas

一. 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

Atas ialah kandungan terperinci jsonp实现原理解析. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn