前后端联调时跨域

最近维护一个老项目的时候,需要和前端联调,我在我本地启动后台项目,前端同事在他本地启动前端项目,调了很久后端代码,总是跨域,后端配置各种header参数都不好使。

解决思路,用nginx代理,让项目仿佛运行在同一个电脑。

前提,你俩项目能单独访问到,能ping或者telnet通。

举例个例子,
前端项目地址为 192.168.1.31:3000/xxxfront/。
后端项目地址为 192.168.1.32:4000/xxxback。
前端同事用他的项目指向你的后端项目时,提示跨域,此时,需要使用nginx配置。

server {
        listen       8099;
        server_name  localhost;
		#前端访问地址不能配置成下面这样,会导致只能访问静态文件,如果前端要调试,很多css js文件访问失败。
		#location /xxxfront 
		#{ 
		#   proxy_pass http://192.168.1.31:3000/; 
		#}
        location / {
			proxy_pass http://192.168.1.31:3000/;
        }
        
        #后端访问地址
        location /xxxback {
			proxy_pass http://192.168.1.32:4000;
        }
        
   }

nginx在后端电脑上配置好后,前端项目不直接访问后端的路径,
改为访问后端nginx代理地址 http://192.168.1.32:8099/xxxback,
项目最终访问 http://192.168.1.32:8099/xxxfront/

画个图解释一下
在这里插入图片描述

最总访问地址http://192.168.1.32:8099/xxxfront/,因为都是通过nginx转发的,浏览器会认为访问ip、端口都一样,解决跨域。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值