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

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

前端代理部分

代理后页面请求地址截图:
在这里插入图片描述
这里地址栏的地址是: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;
		
		 # 指定允许其他域名访问        
         add_header Access-Control-Allow-Origin $http_origin;
         # 允许的请求类型
         add_header Access-Control-Allow-Methods GET,POST,OPTIONS;
         # 许的请求头字段
         add_header Access-Control-Allow-Headers "Origin, X-Requested-With, Content-Type, Accept";

		#验证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";
			}
			# 判断不为空 且 不在白名单内,返回403
			if ($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

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: Nginx 方向代理可以解决跨域问题,它是一种可以代理服务器,可以将客户端发给代理服务器的请求转发到目标服务器,并将目标服务器的响应转发给客户端,从而解决跨域问题。下面是一个简单的代码实现例子:location / { proxy_pass http://example.com; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; } ### 回答2: nginx是一款高性能的Web服务器和反向代理服务器,也可以作为一个负载均衡器使用。通过nginx的反向代理功能,可以解决跨域问题。 跨域问题是由于浏览器的同源策略(Same-origin policy)导致的,同源策略是浏览器的一种安全机制,限制了不同源(协议、域名和端口)之间的交互。但是在实际开发中,有时需要不同域之间的交互,这就需要解决跨域问题。 使用nginx解决跨域问题的方法是,将需要跨域的请求通过nginx进行代理转发。具体步骤如下: 1. 在nginx的配置文件中添加以下代码: ```nginx location /api { add_header Access-Control-Allow-Origin *; proxy_pass http://api.example.com; } ``` 以上配置中,`/api`是要访问的接口地址,`http://api.example.com`是目标服务器的地址。`add_header Access-Control-Allow-Origin *;`表示允许所有来源进行访问。 2. 重启nginx服务器生效。 这样配置后,当前端代码请求`/api`接口时,浏览器会先发送请求给nginx,然后nginx会将请求转发给目标服务器。这样一来,前端的请求就不再属于跨域请求,可以正常获取响应。 具体案例中,假设有一个前端项目部署在`http://frontend.com`,需要调用`http://api.example.com`提供的接口。如果直接调用会遇到跨域问题,可以通过nginx代理解决。具体步骤如下: 1. 修改nginx配置文件`nginx.conf`,添加以下代码: ```nginx server { listen 80; server_name frontend.com; location / { root /path/to/frontend; index index.html; } location /api { add_header Access-Control-Allow-Origin *; proxy_pass http://api.example.com; } } ``` 以上配置中,将前端项目的根目录指定为`/path/to/frontend`,`index.html`为入口文件。同时配置`/api`的反向代理。 2. 重启nginx服务器生效。 这样在浏览器中访问`http://frontend.com`,就可以正常调用`http://api.example.com`上的接口了。 总之,通过nginx的反向代理功能可以解决跨域问题,只需在nginx的配置文件中添加相应的配置即可。具体的配置内容可以根据实际需求进行调整。 ### 回答3: Nginx是一个高性能的开源的Web服务器和反向代理服务器,它可以用于解决跨域问题。跨域问题指的是在浏览器中通过JavaScript发送跨域请求时会受到同源策略的限制,即只能请求同一域名下的资源。 Nginx的方向代理功能可以通过配置实现跨域请求。具体的配置如下: 1. 打开nginx.conf文件,在http块中添加以下内容: ```nginx http { ... server { listen 80; server_name yourserver.com; # 解决跨域问题 location /api/ { proxy_pass http://api.example.com/; add_header Access-Control-Allow-Origin *; add_header Access-Control-Allow-Methods 'GET, POST, OPTIONS'; add_header Access-Control-Allow-Headers 'DNT,User-Agent,X-Requested-With,If-Modified-Since,Cache-Control,Content-Type,Range'; add_header Access-Control-Allow-Credentials true; } } } ``` 2. 上述代码中,`proxy_pass`指令将请求转发到`http://api.example.com/`地址,可以替换为实际的目标服务器地址。 3. `add_header`指令添加跨域相关的头信息,`Access-Control-Allow-Origin`设置为*表示允许任意域名访问,这只适用于测试环境,生产环境中应指定具体的域名。 4. 其他的`Access-Control-Allow-Methods`、`Access-Control-Allow-Headers`和`Access-Control-Allow-Credentials`用于定义允许的HTTP方法、请求头和携带认证信息的设置。 这样配置完成后,当浏览器发送请求到`http://yourserver.com/api/`时,Nginx会将请求转发到`http://api.example.com/`,并添加跨域相关的响应头信息。 一个具体的案例可以是,假设前端页面是通过域名`http://frontend.com`访问的,需要请求后端API服务器`http://backend.com/api/`。可以通过Nginx的方向代理功能,将前端的请求转发到后端API服务器,并解决跨域问题。配置中`Access-Control-Allow-Origin`需要设置为`http://frontend.com`,确保只允许指定的前端域名访问API。 在实际代码中,nginx.conf是Nginx的配置文件,需要根据具体环境进行配置,如监听的端口、服务器名称等。需要将配置文件保存,然后重启Nginx服务,使得配置生效。 通过上述配置和实现,Nginx可以方便地解决跨域问题,同时提供了更灵活的配置选项用于满足各种复杂的跨域需求。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

焚目圣僧渡众生

你的 一角将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值