js常见跨域解决方案

参考:前端常见跨域解决方案(全)

跨域,什么是“域”?

这里就要先说说同源策略了。所谓同源是指"协议+域名+端口"三者相同,即便两个不同的域名指向同一个ip地址,也非同源。

同源策略限制以下几种行为:

1.) Cookie、LocalStorage 和 IndexDB 无法读取

2.) DOM 和 Js对象无法获得

3.) AJAX 请求不能发送

跨域常见解决方案

1.jsonp

原理:ajax请求受同源策略影响,不允许进行跨域请求,而script标签src属性中的链接却可以访问跨域的js脚本,利用这个特性,服务端不再返回JSON格式的数据,而是返回一段调用某个函数的js代码,在src中进行了调用,这样实现了跨域。

jsonp的实现可以查看下面这个链接

菜鸟教程jsonp

缺点:只能发送get请求

2.postMessage跨域

postMessage是HTML5 XMLHttpRequest Level 2中的API,且是为数不多可以跨域操作的window属性之一,它可用于解决以下方面的问题:

a.) 页面和其打开的新窗口的数据传递

b.) 多窗口之间消息传递

c.) 页面与嵌套的iframe消息传递

d.) 上面三个场景的跨域数据传递

html5 postMessage解决跨域、跨窗口消息传递

3.跨域资源共享(CORS)

a.) 普通跨域请求:只服务端设置Access-Control-Allow-Origin即可,前端无须设置。

b.) 带cookie请求:前后端都需要设置字段,另外需注意:所带cookie为跨域请求接口所在域的cookie,而非当前页。

c.) 目前,所有浏览器都支持该功能(IE8+:IE8/9需要使用XDomainRequest对象来支持CORS)),CORS也已经成为主流的跨域解决方案。

CORS简介

4.其他跨域方式

1、 document.domain + iframe跨域

2、 location.hash + iframe

3、使用websocket(Websocket原理及使用场景[转载]

4、使用nginx反向代理(nginx反向代理-解决前端跨域问题

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 原文地址:原文地址 什么是跨域? 跨域是指一个域下的文档或脚本试图去请求另一个域下的资源,这里跨域是广义的。 广义...
    C_Y大渔阅读 4,987评论 1 13
  • 什么是跨域? 2.) 资源嵌入:、、、等dom标签,还有样式中background:url()、@font-fac...
    电影里的梦i阅读 6,940评论 0 5
  • <转>详解跨域(最全的解决方案) 什么是跨域跨域,是指浏览器不能执行其他网站的脚本。它是由浏览器的同源策略造成的,...
    涅槃快乐是金阅读 10,347评论 0 3
  • 1、好雨知时节,当春乃发生,春雨贵如油,天街小雨润如酥。哎哟,背不下去了,反正就是下雨了,空气好,心情好。 2、腿...
    高琳旭阅读 48评论 0 0
  • 忘记是通过什么途径得到的推荐,我买了宁远的《和喜欢的一切在一起》的实体书,光是书的名字,我就喜欢上了。现在的手机A...
    一小只刀豆阅读 1,865评论 0 0