美文网首页
关于跨域

关于跨域

作者: 风吹过的空气 | 来源:发表于2017-08-21 15:48 被阅读16次

跨域的几种方法及优缺点

1. JSONP跨域

优点:它不像XMLHttpRequest对象实现的Ajax请求那样受到同源策略的限制,它的兼容性更好,在更古老的浏览器中都可以运行,不需要XMLHttpRequest或ActiveX的支持,并且在请求完毕后可以通过调用callback的方式回传结果
缺点:它只支持get请求而不支持post等其他类型的HTTP请求;它只支持跨域HTTP请求这种情况,不能解决不同域的两个页面之间如何进行Javascript调用的问题

通过CORS跨域(只要服务器实现了CORS接口,就可以跨域通信)

CORS(Cross-Origin Resource Sharing)跨域资源共享,定义了必须在访问跨域资源时,浏览器与服务器应该如何沟通。CORS背后的基本思想就是使用自定义的HTTP头部让浏览器与服务器进行沟通,从而决定请求或响应是应该成功还是失败。目前所有浏览器都支持这个功能,IE浏览器不能低于10。整个CORS通信过程,都是浏览器自动完成,不需要用户参与。对于开发者来说,CORS通信与同源的AJAX通信没有差别,代码完全一样。浏览器一旦发现AJAX请求跨源,就会自动添加一些附加的头信息,有时还会多出一次附加的请求,但用户不会有感觉

  • CORS与JSONP对比
    • JSONP只能实现GET请求,而CORS能实现所有的HTTP请求。
    • 使用CORS,开发者可以使用普通的XMLHttpRequest发起请求和获得数据,比起JSONP有更好的错误处理
    • JSONP主要被老的浏览器支持,它们旺旺不支持CORS,而绝大多数现代浏览器都已经支持CORS
      总结:CORS与JSONP相比,无疑更为先进、方便和可靠

通过HTML5的postMessage跨域

高级浏览器IE8+,chrome,Firefox,Opera,Safari都支持这个功能。这个功能主要包括接受信息的“message”事件和发送消息的“postMeassage”方法。比如demo.cn域的A页面通过iframe嵌入了一个google.com域的B页面,可以通过以下方式实现A和B的通信

A页面通过postMessage方法发送信息:

window.onload = function() {
  var ifr = document.getElementById('ifr');
  var targetOrigin = "http://www.google.com";
  ifr.contentWindow.postMessage('hello world', targetOrigin);
}

postMessage的使用方法:

  • otherWindow.postMessage(message, targetOrigin)
    • otherWindow:指目标窗口,也就是给哪个window发消息,是window.frames属性的成员或者由window.open方法创建的窗口
    • message:是要发送的消息,类型为String、Object(IE8、9不支持)
    • targetOrigin: 是限定消息接收范围,不限制请使用

B页面通过message事件监听并接受消息:

var onmessage = function (event) {
  var data = event.data;
  var origin = event.origin;
  var source = event.source;
  if (origin === 'http://www.baidu.com') {
    console.log(data);
  }
}
if (typeof window.addEventListener !== 'undefined') {
  window.addEventListener('message', onmessage, false);
} else if (typeof window.attachEvent !== 'undefined') {
  window.attchEvent('onmessage', onmessage);
}

同理,也可以B页面发送消息,然后A页面监听并接受消息

通过 document.domain 跨域

通过 location.hash 跨域

通过 window.name 跨域

相关文章

  • JavaScript - GET/POST及跨域方法

    xhr 原生方法请求 window fetch 方法 关于跨域 利用JSONP实现跨域调用 使用 CORS(跨域资...

  • window.URL 与 跨域

    跨域 关于跨域问题,简单来说就是通过地址访问资源时,所用的协议不同导致无法访问目标。 网上已经有很多关于跨域的主流...

  • 跨域

    关于跨域大概可以分为 iframe 的跨域和纯粹的跨全域请求。 3种跨全域方法: 1、JSONP 全称:JSON ...

  • 跨域的解决方式与演示

    关于跨域大概可以分为 iframe 的跨域和纯粹的跨全域请求。 3种跨全域方法: 1、JSONP 全称:JSON ...

  • 无标题文章

    关于axios跨域的问题

  • 跨域请求CORS

    前沿: 最近总听到同事聊跨域得问题,于是自己抽空仔细的查阅了一下关于跨域的知识。说到跨域,就得提到同源,跨域是指一...

  • vue 跨域的配置

    关于跨域的配置真是累呀 在网上找了资料 才成功实现跨域了 其实主要在vue.config.js 来配置跨域

  • 跨域与常用方案

    本文源自一次内部关于跨域的讨论分享的总结 理解跨域的重点在于:了解跨域产生的场景、原理 跨域问题只在浏览器客户端环...

  • 前端踩过的坑

    关于前端 跨域问题 大概问题 1,前端无须处理,需要在后台配置 niginx的配置 处理跨域的域名 关于布局上 ...

  • Spring Boot跨域

    前后端分离时候势必会遇到Ajax跨域请求。 1. 关于跨域 参考跨域资源共享 CORS 详解 CORS是一个W3C...

网友评论

      本文标题:关于跨域

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