您好,欢迎访问一九零五行业门户网

jsonp实现原理解析

一. jsonp实现原理是利用script标签可以获取不同源资源的特点,来达到跨域访问某个资源的目的。具体行为如下:
创建一个script标签,将请求地址写入它的src属性,将这个script外链插入head标签中;
声明一个回调函数callback,函数名和请求地址中的一致;
请求地址的内容是一个以json对象为参数的执行函数callback;
当script资源载入时,callback开始执行,将json数据输出。
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请求。
四. 其他跨域方式
cors(cross-origin resource sharing)跨域资源共享,服务器端设置access-control-allow-origin,如果浏览器检测到相应的设置,就会允许访问;
修改document.domain,将子域和主域的document.domain设为同一个主域;
window.name,每个页面都对window.name有读写的权限,window.name持久存在在一个窗口载入过的所有页面中;
window.postmessage
以上就是 jsonp实现原理解析的详细内容。
其它类似信息

推荐信息