前端跨域解决方案

什么是跨域?

跨域是指一个域下的文档或脚本试图去请求另一个域下的资源。


同源策略:

同源是指“协议+域名+端口”三者相同。


跨域解决方案:

1.通过jsonp跨域;

2.document.domain+iframe跨域;

3.location.hash+iframe跨域;

4.window.name+iframe跨域;

5.postMessage跨域;

6.跨域资源共享(CORS);

7.nginx代理跨域;

8.nodejs中间件代理跨域;

9.WebSocket协议跨域;


1)通过jsonp跨域

我们知道在<html>中通过<script>标签请求其他域时不会存在跨域问题,那么基于此原理我们可以动态创建script,再请求一个带参网址实现跨域通信。

1.可以原生实现;

2.jquery ajax实现:指定dataType: jsonp

缺点:只能实现get一种请求。


2document.domain+iframe跨域

此方案仅限主域相同,子域不同的跨域场景。

实现原理:两个页面都通过js强制设置document.domain为基础主域,就实现了同域。


3location.hash+iframe跨域

实现原理:a域与b域相互通信,通过中间页c来实现。三个页面,不同域之间利用iframelocation.hash传值,相同域之间直接js访问来通信。


4window.name+iframe跨域


5postMessage跨域

postMessageHTML5 XMLHttpRequest Level 2中的API,且是为数不多可以跨域操作的window属性之一。


6)跨域资源共享(CORS

普通跨域请求:只服务端设置Access-Control-Allow-Origin即可,前端无需设置,若要带cookie请求,前后端都需要设置。

目前,所有浏览器都支持该功能,CORS也已经成为主流的跨域解决方案。

1.前端设置:

原生ajaxjQuery ajaxvue框架

xhr.withCredentials = true;   //前端设置是否带cookie

2.服务端设置:

java后台、nodejs后台

Response.setHeader(“Access-Control-Allow-Origin”,”http://www.jinjumao.club”);

response.setHeader(“Access-Control-Allow-Credentials“,”true”);


7nginx代理跨域

1.nginx配置解决iconfont跨域

location / {

add_header Access-Control-Allow-Origin *;

}

2.nginx反向代理接口跨域

实现思路:通过nginx配置一个代理服务器(域名与domain1相同)做跳板机,反向代理访问domain2接口,并且可以顺便修改cookiedomain信息,方便当前域cookie写入,实现跨域登录。


8Nodejs中间件代理跨域

node中间件实现跨域代理,原理大致与nginx相同,都是启用一个代理服务器,实现数据的转发,也可以通过设置cookieDomainRewrite参数修改响应头中cookie中域名,实现当前域的cookie写入,方便接口登录认证。

1.vue框架的跨域

利用node+express+http-proxy-middleware搭建一个proxy服务器。

2.vue框架的跨域

利用node+webpack+webpack-dev-server代理接口跨域。在开发环境下,由于vue渲染服务和接口代理服务都是webpack-dev-server同一个,所以页面与代理接口之间不再跨域,无须设置headers跨域信息了。


9WebSocket协议跨域

WebSocket protocolHTML5一种新的协议,它实现了浏览器与服务器全双工通信,同时允许跨域通讯。













  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值