事情是这样的,有个需求,就是在本系统准备把所有的api 请求放到webman 框架
然后把后台的业务依然保留在fastadmin 框架,
打算加一个反向代理,用同一个域名的加上一个访问后缀,放到到webman 服务,也就是本地的127.0.0.1:8787 端口
一开始的写法就是

这样的话访问http://**** /aaa的话就转发到 127.0.0.1:8787端口的aaa 目录,那我访问http://**** /bbb的话,就访问不到127.0.0.1:8787端口的bbb目录,因为我没有配置bbb 目录的代理,这样的话,我有多少个controller 就要配置多少个正则location才能去访问,那显然是不符合我的需求的,我要的是,访问http://**** /aaa 的话能转发到127.0.0.1:8787服务就可以,而不是到aaa目录,也就是说,我要想办法去掉这个location的匹配路径,于是乎我多番查找,终于让我找到
以下是参考文章
1. location和proxy_pass都带/去除
location ^~/api/ {
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-NginX-Proxy true;
proxy_pass http://api/;
}
http://api/ 的 api后面带/, 则会移除api这个上下文
这个办法,在宝塔报错,死活不行
2. rewrite去除
location ^~/api/ {
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-NginX-Proxy true;
rewrite ^/api/(.*)$ /$1 break;
proxy_pass http://api;
}
http://api 的 api后面不带/, 通过rewrite移除api这个上下文
最后采用rewrite方法,这个好,终于解决了我的问题,可以去掉上下文,感恩
3. location带/, proxy_pass不带上下文去除
# 转发示例:
# 请求:http://aaa.com/system/path/request
# 转发:http://bbb.com/path/request
#
location ^~ /system/ {
proxy_pass http://bbb.com;
}
这个也不行,试过了
保留
1. location不带/, proxy_pass不带上下文保留
# 转发示例
# 请求:http://aaa.com/system/path/request
# 转发:http://bbb.com/system/path/request
#
location ^~ /system {
proxy_pass http://bbb.com;
}
参考文章地址:https://www.cnblogs.com/mengff/p/16788194.html





![[NSSRound#23 misc] 前两题](https://img-blog.csdnimg.cn/direct/63ca0a1b04604f619366facde9b7c384.png)













