前端添加代理通过nginx进行转发解决跨域

news/2024/12/23 2:42:56/

记录在项目中遇到跨域并进行解决的方案

解决方案

  • 记录在项目中遇到跨域并进行解决的方案
  • 前端代理部分
  • nginx转发
  • 配置origin限制,修复CORS跨域漏洞

前端代理部分

代理后页面请求地址截图:
在这里插入图片描述
这里地址栏的地址是:http://127.0.0.1:13908
调用登录接口请求地址是:http://127.0.0.1:13908/api/sys/login
后端网关的端口不是13908,是13909,且没有api,这里是前端加了代理

nginx转发

nginx配置如下,监听前端访问的端口,并且拦截并转发到我们需要的地址。

	server {listen       13908;        server_name  localhost;location / { root   /home/cdszwy/phase2Test/web/html;index  index.html;try_files $uri $uri/ /index.html;	}#/api  会拼在url后面( http://127.0.0.1:13909/api/sys/login) ,/api/  不会拼在url后面( http://127.0.0.1:13909/sys/login)#拦截 端口 + /api, 然后做转发#遇到/api的请求 nginx 转发到某某 服务器ip端口#13908 是你前端的地址  好或者前端请求的端口location /api/ {proxy_pass   http://127.0.0.1:13909/;}

配置origin限制,修复CORS跨域漏洞

第一种:

	map $http_origin $allow_cros {default 1;#这里的ip或者域名是你自己服务的,也就是你允许访问的地址进行匹配,可以添加多个,外部地址匹配不上将不允许访问"~^(http://127.0.0.1:13908)$" 1;"~*" 0;}server {listen       13908;        server_name  localhost;#验证origin是否匹配,不匹配则返回403,不允许访问if ($allow_cros = 0){return 403;}location / { root   /home/cdszwy/phase2Test/web/html;index  index.html;try_files $uri $uri/ /index.html;	}#/api  会拼在url后面( http://127.0.0.1:13909/api/sys/login) ,/api/  不会拼在url后面( http://127.0.0.1:13909/sys/login)#拦截 端口 + /api, 然后做转发#遇到/api的请求 nginx 转发到某某 服务器ip端口#13908 是你前端的地址  好或者前端请求的端口location /api/ {proxy_pass   http://127.0.0.1:13909/;}

第二种配置:

	server {listen       13908;        server_name  localhost;location / { root   /home/cdszwy/phase2Test/web/html;index  index.html;try_files $uri $uri/ /index.html;	}#/api  会拼在url后面( http://127.0.0.1:13909/api/sys/login) ,/api/  不会拼在url后面( http://127.0.0.1:13909/sys/login)#拦截 端口 + /api, 然后做转发#遇到/api的请求 nginx 转发到某某 服务器ip端口#13908 是你前端的地址  好或者前端请求的端口location /api/ {set $allow_cors 0;# 判断不为空if ($http_origin) {set $allow_cors 1;}# 判断不在白名单内if ($http_origin !~* "(127.0.0.1)" ) {set $allow_cors "${allow_cors}1";}# 判断不为空 且 不在白名单内,返回403if ($allow_cors = "11") {return 403;}add_header 'Access-Control-Allow-Origin' $allow_cors always;add_header 'Access-Control-Allow-Credentials' 'false'  always;proxy_pass   http://127.0.0.1:13909/;access_log   /usr/local/nginx/log/uat-mobileapi-access.log;error_log    /usr/local/nginx/log/uat-mobileapi-error.log;}

以上两种测试后都能满足该场景,但是设置:add_header ‘Access-Control-Allow-Origin’ $allow_cors always;并未生效,都是通过匹配原则进行判断来做的返回退出,后面有时间再进行验证 add_header的方式

有什么更好的欢迎留在评论区。

参考文章:
https://blog.csdn.net/qq_20236937/article/details/128640137
https://blog.csdn.net/qq_33204709/article/details/129232198
https://blog.csdn.net/zxd1435513775/article/details/102508463


http://www.ppmy.cn/news/485418.html

相关文章

gitops

gitOps 持续化集成部署/交付流程解释 一、gitOps整个过程拓扑图 手绘gitOps.pdf 二、每个系统在GitOps流程中占据的角色和作用 2.1 gitlab 功能1 首先,gitlab作为公司自建的代码仓,原本的定位是仅作为代码仓使用,现在经过改良&#xff…

软件测试行业即将迎到尽头?

前两天跟一个HR朋友聊天,她表示刚在boss上发布了一个普通测试岗位,不到一小时竟然收到了几百份简历。而且简历质量极高,这是往年不敢想象的。岗位少,竞争激烈,这是今年软件测试就业的真实写照,也是所有岗位…

电影APP项目(Android+Java+MySQL)

目录: 一、系统架构:二、效果图:1.主页:2.榜单页:3.预告片页:4.动态评论页:5.登录页: 三、数据库设计:四、详细设计:1.主页:2.榜单页:…

在各种大厂干了 2 年,软件测试道路坎坷无限啊

先简单交代一下背景吧,某不知名985的本硕,17年毕业加入滴滴,之后跳槽到了头条,一直从事软件测试相关的工作。之前没有实习经历,算是两年半的工作经验吧。 这两年半之间完成了一次晋升,换了一家公司&#x…

电池电机整车功率需求转换关系

纯电动汽车SOC达到最低限定值时整车限功率原因 1、 纯电动整车构造如上图所示:1、动力电池 2、直流母线 3、电机控制器(MCU) 4、三相线 5、电机 6、低压信号线 7、整车控制器(VCU) 2、能量流向:当车辆有能…

matlab 仿真三项异步电机,基于MATLAB三相异步电机的建模与仿真

来稿时间 : 2005年 8月 基于 MATLAB三相异步电机的建模与仿真 刘硕 彭江川 摘 要 利用 MATLAB软件中的动态仿真工具 SIMUL INK,建立了异步电机的仿真模型 ,并通过实验验证了所建电机模型的可行性和实用性 ,在二相任意坐标系下建立三相异步电机的仿真模型 ,从异步电机矢量控制数…

三相无刷电机HALL、ABI、UVW的逻辑关系

一、编码器的分类 根据检测原理,编码器可分为光学式、磁式、感应式和电容式,根据其刻度方法及信号输出形式,可分为增量式、绝对式以及混合式三种。 1、增量式编码器 增量式编码器是直接利用光电转换原理输出三组方波脉冲A、B和Z相&#xff…

三相短路实用计算机的内容是,第七章电力系统三相短路的实用计算.doc

{精编资料} 第七章 电力系统三相短路的实用计算. 内容要点. 电力系统故障计算。可分为实用计算的“手算”和计算机算法。大型电力系统的故障计算,一般均是采用计算机算法进行计算。 ... 第七章 电力 系统 三相 短路 实用 计算 内容 要点 故障 分为 计算机 算法 大型 一般 均是…