网站首页 > 技术教程 正文
# 为什么会产生跨域问题
- 浏览器限制,目前所有浏览器都实现了同源策略规范。
- 请求方式Type为xhr。如果非xhr,如json,script则也不会存在跨域问题
- 请求方与服务方的源不同,即跨域,包括:
- 协议不同
- 域名不同
- 端口不同
同时满足三个条件才有可能产生跨域问题。
# 解决方案
- 对于浏览器限制的解决方案-关闭浏览器的同源策略检查
- --args--disable-web-security--user-data-dir设置浏览器的启动参数,将浏览器的同源策略取消。该方式要求所用的用户进行手动操作,肯定是不现实的。
- 请求方式Type为xhr的解决方案既然只有Type为xhr的请求才会存在跨域请求,那么我们是不是可以换一种请求方式呢。Jsonp的实现就是这样。将原本Type是xhr的请求伪造成script请求。Jsonp的请求路径后面会自动带上callback参数,服务端可据此判断是否是jsonp请求,将返回值以script的形式进行封装。且服务端需要进行相应的改动。
对于SpringBoot项目
@ControllerAdvicepublic
class JsonpAdvice extends AbstractJsonpResponseBodyAdvice{
public JsonpAdvice{
super("callback"); //约定的jsonp请求参数
}
}
JQuery实现jsonp的原理:
动态创建一个script,通过这个script去请求,请求完,该script即被销毁。可通过对jQuery打断点的方式验证。(可以看到JQuery在网页源代码嵌入了一个临时的script,当Jsonp请求完成之后,该Script即被销毁)
- 弊端:
- 服务器需要改动
- 只支持GET方式 (因为获取script都是GET方式,前端指定请求方式也无效,还以GET方式发起的请求)
3. 对于域不同的解决方案
根据实际系统架构来决定使用哪种方式
- 被调用方解决返回的响应头的包含允许跨域访问的信息,需要被调用方进行代码的修改。(可由具体应用添加允许跨域信息,也可以由容器,Tomcat,jetty等添加)
- 通过Filter实现
- 将允许跨域请求的信息配置在nginx或者apache转发服务器
2. 调用方解决
在调用方与被调用方中间再增加一层,该层做转发,将调用方的请求转发到被调用方。其中第一点因为调用方与该转发层在同一个域名下,所以不会有跨域问题。第二点,由于不是浏览器发起的请求,所以转发层调用被调用方也是不存在跨域问题的(参见跨域的三要素)。
简单请求与非简单请求
当浏览器发起一个跨域请求的时候会先判断是简单请求还是非简单请求。
对于简单请求,浏览器会先请求,拿到结果后再判断是否跨域。
对于非简单请求,浏览器会先发起一个预检options请求,检查通过之后再发起实际的请求。
对于带cookie的跨域请求,
- 需要将allowedOrigins设置为具体的origin,而不能使用 *。
- 需要设置响应参数 allowCredentials(true),允许带cookie的跨域
- 上一篇: 如何为Golang服务器(进程)分配域名?
- 下一篇: Nginx 部署前后端分离项目,解决跨域问题
猜你喜欢
- 2024-10-14 Nginx 部署前后端分离项目,解决跨域问题
- 2024-10-14 如何为Golang服务器(进程)分配域名?
- 2024-10-03 来,跨个域看看 (CORS)(跨域详解)
- 2024-10-03 Debian安装Nginx并搭建静态网站服务器-OnceAI
- 2024-10-03 Nginx 部署前后端分离项目,解决跨域问题
- 2024-10-03 如何在Ubuntu 20.04上安装Nginx(ubuntu24.04安装教程)
- 2024-10-03 kubernetes从入门到精通系列04-入门命令
- 2024-10-03 「技术架构」在5分钟把前端应用程序安装到NGINX
- 2024-10-03 WebSocket能干些啥?(websocket介绍)
- 2024-10-03 Nginx与前端的羁绊(nginx部署前端vue)
你 发表评论:
欢迎- 最近发表
-
- 阿里P8大佬总结的Nacos入门笔记,从安装到进阶小白也能轻松学会
- Linux环境下,Jmeter压力测试的搭建及报错解决方法
- Java 在Word中合并单元格时删除重复值
- 解压缩软件哪个好用?4款大多数人常用的软件~
- Hadoop高可用集群搭建及API调用(hadoop3高可用)
- lombok注解@Data没有toString和getter、setter问题
- Apache Felix介绍(apache fineract)
- Spring Boot官方推荐的Docker镜像编译方式-分层jar包
- Gradle 使用手册(gradle详细教程)
- 字节二面:为什么SpringBoot的 jar可以直接运行?
- 标签列表
-
- 下划线是什么 (87)
- 精美网站 (58)
- qq登录界面 (90)
- nginx 命令 (82)
- nginx .http (73)
- nginx lua (70)
- nginx 重定向 (68)
- Nginx超时 (65)
- nginx 监控 (57)
- odbc (59)
- rar密码破解工具 (62)
- annotation (71)
- 红黑树 (57)
- 智力题 (62)
- php空间申请 (61)
- 按键精灵 注册码 (69)
- 软件测试报告 (59)
- ntcreatefile (64)
- 闪动文字 (56)
- guid (66)
- abap (63)
- mpeg 2 (65)
- column (63)
- dreamweaver教程 (57)
- excel行列转换 (56)
本文暂时没有评论,来添加一个吧(●'◡'●)