如何在nginx中进行路径的重写并进行转发到指定服务器

  1. 在我们的前后端开发过程中,如果前端页面在请求后台服务器的时候,在url中都会存在/api这个请求前缀,但是我们的后台服务接口中却没有/api的路径,那么在不修改服务端代码的情况下,我们可以通过nginx来轻松解决这个问题。
    1. 前端请求路径为:http://192.168.xxx.xxx:8080/api/users/1725808854490013697
    2. 实际上后端只存在的接口为:http://192.168.xxx.xxx:8080/users/1725808854490013697
    3. 那么这种情况下,代码不经过修改的前提下,前端是无法正常访问后端接口
  2. 为了实现上面的需求,我们可以通过nginx进行路径的重写然后再转发到服务器
    1. 我们需要在nginx的nginx.conf的配置文件中,添加以下反向代理的配置即可实现当前功能
      1.

      java 复制代码
              location ^~ /api/ {
                  # 路径重写
                  rewrite ^/api/(.*)$ /$1 break;
                  # 反向代理配置,将请求转发到指定的服务
                  proxy_pass http://192.168.xxx.xxx:8080;
              }
    2. 指令的详细说明

      1. location ^~ /api/

        1. "^~":表示普通字符串匹配上以后不再进行正则匹配

        2. 以/api/开头的请求,都会匹配上

      2. rewrite ^/api/(.*) /1 break;

        1. rewrite:路径重写

        2. 这里写的是一个正则表达式,代表如果请求路径是以/api/开头,后面的请求路径任意,此时将原始的url路径重写为/$1,这里的$1指代的就是通配符 .* 这一块的内容。比如:

          html 复制代码
          /api/users/1725808854490013697 -------> ^/api/(.*)$ --------> 此时 (.*) 匹配的就是 users/1725808854490013697 ------> 最终重写为/$1 即 /users/1725808854490013697
      3. proxy_pass http://192.168.xxx.xxx:8080;

        1. proxy_pass:反向代理

        2. 路径重写后的请求,将会转发到后端的http://192.168.xxx.xxx:8080服务器

相关推荐
ITOWARE_SAPer14 小时前
选择SAP实施公司能否兼得官方授权与高性价比?
运维·能源·制造·零售
Elastic 中国社区官方博客15 小时前
Elasticsearch:快速近似 ES|QL - 第一部分
大数据·运维·数据库·elasticsearch·搜索引擎·全文检索
AC赳赳老秦16 小时前
OpenClaw生成博客封面图+标题,适配CSDN视觉搜索,提升点击量
运维·人工智能·python·自动化·php·deepseek·openclaw
Eric.Lee202116 小时前
docker 启动停止命令
运维·docker·容器
samson_www17 小时前
EC2的GRUB引导程序问题
运维·ai
代码中介商17 小时前
Linux 帮助手册与用户管理完全指南
linux·运维·服务器
weixin_4491736519 小时前
Linux -- 项目中查找日志的常用Linux命令
linux·运维·服务器
Watermelo61720 小时前
理解 JavaScript 中的“ / ”:路径、资源与目录、nginx配置、请求、转义的那些事
前端·javascript·vue.js·chrome·nginx·正则表达式·seo
深念Y20 小时前
赛米尼M02/海纳斯HiNAS系统-WiFi驱动安装教程
运维·服务器·网络·docker·nas·机顶盒·hinas
会飞的土拨鼠呀20 小时前
Ubuntu24.04安装open-vm-tools
运维·服务器