跨域的几种方法

2016-12-11  本文已影响0人  jeffAAA

概念:只要协议、域名、端口有任何一个不同,都被当作是不同的域。

原理:所有具有src属性的HTML标签都是可以跨域的,包括img标签和script标签

类似image标签和iframe标签,像image标签在更改src属性时会发送请求,可以达到统计的效果.而script, iframe,只有在添加到DOM树之后才会发送HTTP请求      

    var img = new Image();      
    img.src = 'http://some/picture'; // 发送HTTP请求
    var ifr = $('<iframe>', {src: 'http://b.a.com/bar'});
    $('body').append(ifr); // 发送HTTP请求

    
**限制:需要创建一个DOM对象,只能用于GET方法**

**场景:适用于做统计需求时,有后台做开发资源的情况**。

window.name在不同的页面(甚至不同域名)加载后依旧存在(如果没修改则值不会变化),并且可以支持非常长的 name 值(2MB)

首先插入iframe 其src属性指向服务器文件地址(利用iframe标签的跨域能力),服务器文件里设置好window.name的值(也就是该iframe的contentWindow的name值),然后在index.html里读取该iframe的window.name值。服务端可以输出类似这样的js

``

window.name = "{"name":"hanzichi", "age":10}";
``

这样可以达到跨域获取资源的目的。

**限制:不支持其他页面不能配合修改的情况**

**场景:适用于指服务器文件可以配合开发的情况**

适用于主域相同,子域不同情况。
例如在a.xxx.com/a.html 和 b.xxx.com/b.html中,都设置document.domain = 'xxx.com';

`document.domain = 'xxx.com'`

再在a.html中插入iframe,src为b.html的链接
此时可以在iframe的onload方法里调用b.html的dom,
达到跨域的效果

**限制:安全性不足,当a.html被攻击后,b.html也可能受影响**

**场景:适用于跨子域的情况,并且两个页面都需要修改,好处是没有后台开发资源**
**场景:适用于有后台开发资源,对方页面不可以修改的情况,需要前后端都规定好写法,   不受浏览器兼容性的影响**

*注意: ajax和jsonp其实本质上是不同的东西。ajax的核心是通过XmlHttpRequest获取非本页内容,而jsonp的核心则是动态添加script标签来调用服务器提供的js脚本。*

postMessage()方法允许来自不同源的脚本采用异步方式进行有限的通信,可以实现跨文本档、多窗口、跨域消息传递。

在一个页面里调用``postMessage(data,origin)``

data指传送的数据,origin指目标窗口的源,在另一个页面里监听window的message事件

window.addEventListener('message',function(){...})

限制:注意IE8及小于IE8的版本不支持addEventListener,浏览器需要支持HTML5,受浏览器影响

**场景:适用于两个页面都可以修改,好处是不需要后台开发资源**

现在主要使用jsonp,但是跨域的正道还是要推荐HTML5提供的CORS头字段以及window.postMessage, 可以支持POST, PUT等HTTP方法,从机制上解决跨域问题。

上一篇 下一篇

猜你喜欢

热点阅读