事情是这样的,有个需求,就是在本系统准备把所有的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

Logo

开放原子开发者工作坊旨在鼓励更多人参与开源活动,与志同道合的开发者们相互交流开发经验、分享开发心得、获取前沿技术趋势。工作坊有多种形式的开发者活动,如meetup、训练营等,主打技术交流,干货满满,真诚地邀请各位开发者共同参与!

更多推荐