博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
前端跨域解决方案
阅读量:4091 次
发布时间:2019-05-25

本文共 1810 字,大约阅读时间需要 6 分钟。

什么是跨域?

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

同源策略:

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

跨域解决方案:

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一种请求。

(2)document.domain+iframe跨域

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

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

(3)location.hash+iframe跨域

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

(4)window.name+iframe跨域

(5)postMessage跨域

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

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

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

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

1.前端设置:

原生ajax、jQuery ajax、vue框架

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

2.服务端设置:

java后台、nodejs后台

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

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

(7)nginx代理跨域

1.nginx配置解决iconfont跨域

location / {

add_header Access-Control-Allow-Origin *;

}

2.nginx反向代理接口跨域

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

(8)Nodejs中间件代理跨域

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跨域信息了。

(9)WebSocket协议跨域

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

--------------------- 
作者:Gyoung阿广 
来源:CSDN 
原文:https://blog.csdn.net/u012755393/article/details/79885043 
版权声明:本文为博主原创文章,转载请附上博文链接!

你可能感兴趣的文章
LeetCode Question Difficulty Distribution
查看>>
SDWebImage的原理 和 实现机制 --- tableView 滑动卡的问题
查看>>
boost/config.hpp文件详解
查看>>
奇异值分解和聚类分析操作流程
查看>>
由NodeJS浅谈无敌的前端开发工程师
查看>>
sizeof和小部分c++语法
查看>>
Java中的继承、封装、多态的理解
查看>>
Ubuntu Mininet环境搭建
查看>>
Cloudstack安装(二)
查看>>
iOS 蓝牙 技术
查看>>
BigData – Join中竟然也有谓词下推!?
查看>>
Ajax基础应用入门01
查看>>
Xsrf 验证
查看>>
设计模式(5)--Builder(建造模式)--创建型
查看>>
使用Perl处理Excel之DMA映射
查看>>
实现 select中指定option选中触发事件
查看>>
poj 2182,乱搞
查看>>
《软件评测师教程》-安全测试与评估
查看>>
使用Alcatraz来管理Xcode插件
查看>>
Canvas动画
查看>>