美文网首页
跨域的几种方法

跨域的几种方法

作者: jeffAAA | 来源:发表于2016-12-11 21:53 被阅读0次

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

  • 所有具有 src 属性的HTML标签都可以跨域

原理:所有具有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来进行跨域

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

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

``

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

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

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

**场景:适用于指服务器文件可以配合开发的情况**
  • document.domain+iframe的设置来跨子域

适用于主域相同,子域不同情况。
例如在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也可能受影响**

**场景:适用于跨子域的情况,并且两个页面都需要修改,好处是没有后台开发资源**
  • jsonp(动态插入script)

    浏览器默认禁止了跨域访问,但并不禁止在页面中引用其他域的JS文件.

    JSONP,允许用户传递一个callback参数给服务端,然后服务端返回数据时会将这个callback参数作为函数名来包裹住JSON数据,这样客户端就可以随意定制自己的函数来自动处理返回数据。

    相当于本地函数被跨域的远程js调用,callback大概如下,里面相当于传回的data

    callback({message:"success"})

    限制:

    • 需要创建一个DOM对象并且添加到DOM树,只能用于GET方法

    • 有被攻击的可能,类似于 csrf(cross site request forgery) ,可以通过加token验证的方式来规避风险.

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

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

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

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

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

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

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

**场景:适用于两个页面都可以修改,好处是不需要后台开发资源**
  • 跨域资源共享(CORS)

    原理:服务器设置Access-Control-Allow-OriginHTTP响应头之后,浏览器将会允许跨域请求。

    支持其他的HTTP方法如PUT, POST等,可以从本质上解决跨域问题。

    请求资源时需服务器设置资源的Access-Control-Allow-OriginHTTP响应头

          Access-Control-Allow-Origin: *              # 允许所有域名访问,或者
          Access-Control-Allow-Origin: http://a.com   # 只允许a域名访问  
    

    限制:浏览器需要支持HTML5

    场景:使用于服务器资源可以配合修改响应头的情况


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

相关文章

  • 跨域问题详解分析

    参考文档 CORS详解 跨域资源共享 CORS 详解 js中几种实用的跨域方法原理详解 跨域的那些事儿 跨域与跨域...

  • web跨域解决方案

    围绕以下几点介绍: 什么是跨域? 常用的几种跨域处理方法? crossdomain.xml解决跨域问题 什么是跨域...

  • 跨域

    跨域的几种方法 通过jsonp跨域 在js中,我们直接用XMLHttpRequest请求不同域上的数据时,是不可以...

  • 关于跨域

    跨域的几种方法及优缺点 1. JSONP跨域 优点:它不像XMLHttpRequest对象实现的Ajax请求那样受...

  • iframe

    一、iframe跨域的几种常用方法 1、postmessage window.postMessage方法可以安全地...

  • 跨域问题解决方法

    每个接触前端的人都会遇到前端经典跨域问题,下面介绍几种我所知道的跨解决方法 1.首先什么是跨域?即为不同域名之间相...

  • 跨域问题:好几种解决方案

    跨域分为广义跨域和狭义跨域 广义跨域:一个域下的文档或脚本试图去请求另一个域下的资源; 广义跨域可以分为以下几种:...

  • Ajax 请求和跨域

    跨域的几种方式: cors方式 cross-orign-resource-shareing(跨域)参考:http:...

  • #hello,JS:15 同源策略 & 跨域(JSONP)

    跨域有几种常见的方式?你有没有跨域使用的经验? 方式: 使用jsonp实现跨域?使用cors实现跨域?浏览器另类的...

  • 跨域的解决方式

    跨域有很多种方式,下面就简单说说跨域最常见的几种解决方式1、JSONPJSONP是服务器与客户端跨源通信的常用方法...

网友评论

      本文标题:跨域的几种方法

      本文链接:https://www.haomeiwen.com/subject/tdwpmttx.html