架构师_程序员_码农网

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 8760|回复: 0

[资料] Spring Cloud Gateway CORS 跨域配置

[复制链接]
发表于 2021-7-28 17:39:14 | 显示全部楼层 |阅读模式
项目是前后端分离,前端和后端不在一个端口上面,前端调用后端接口就存在跨域的问题,一次 HTTP 请求,首先达到网关,在经过网关的转发请求到后端。

如果网关为允许跨域,会报错如下:

Access to XMLHttpRequest at 'http://127.0.0.1:9999/gateway/auth/account/requestToken' from origin 'http://localhost:60356' has been blocked by CORS policy: Response to preflight request doesn't pass access control check: No 'Access-Control-Allow-Origin' header is present on the requested resource.
jquery.min.js:2 POST http://127.0.0.1:9999/gateway/auth/account/requestToken net::ERR_FAILED
关于 Spring Cloud Gateway CORS 配置文档教程:https://docs.spring.io/spring-cloud-gateway/docs/current/reference/html/#cors-configuration

修改 application.yml 配置文件如下:

设置完成后,重新运行项目,由于微服务本身也设置了允许跨域,在 POST 响应头会出现重复的内容,报错如下:

Access to XMLHttpRequest at 'http://127.0.0.1:9999/gateway/auth/account/requestToken' from origin 'http://localhost:60356' has been blocked by CORS policy: The 'Access-Control-Allow-Origin' header contains multiple values 'http://localhost:60356, http://localhost:60356', but only one is allowed.
QQ截图20210728173304.jpg QQ截图20210728173156.jpg

解决方案,新建 CorsResponseHeaderFilter 过滤器,剔除一些相同的响应头,代码如下:

新建 CorsConfiguration 文件,注册 Bean,代码如下:

成功解决问题,如下图:

QQ截图20210728173845.jpg

(完)





上一篇:CentOS 7 通过命令将文件复制到另外一台服务器
下一篇:使用 Visual Studio 比较文本差异
码农网,只发表在实践过程中,遇到的技术难题,不误导他人。
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

免责声明:
码农网所发布的一切软件、编程资料或者文章仅限用于学习和研究目的;不得将上述内容用于商业或者非法用途,否则,一切后果请用户自负。本站信息来自网络,版权争议与本站无关。您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容。如果您喜欢该程序,请支持正版软件,购买注册,得到更好的正版服务。如有侵权请邮件与我们联系处理。

Mail To:help@itsvse.com

QQ|手机版|小黑屋|架构师 ( 鲁ICP备14021824号-2 )|网站地图

GMT+8, 2024-4-24 19:15

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表