http-proxy-middleware配置代理部署到Nginx代理无效的解决

在开发中是可以正常访问的如下:

const {createProxyMiddleware} = require('http-proxy-middleware');

module.exports = function (app) {
    app.use(
        createProxyMiddleware('/api', {
            //target: 'http://127.0.0.1:8080',
            target: 'http://172.16.171.139:8090',
            // pathRewrite: {
            //     '^/api': '',
            // },
            changeOrigin: true,
            secure: false, // 是否验证证书
            ws: true, // 启用websocket
        }),
    );
};

请求调用代码如下:
在这里插入图片描述在本地运行访问是没问题,不出现任何404,
如下图展示:
在这里插入图片描述但将程序打包部署到Nginx上时却发现无法正常访问接口报错是404,分析原因如下:
开发程序时,是运行在node环境中,此时使用的是http-proxy-middleware进行代理请求,但是打包部署后并非运行在node环境中,此时需要在Nginx上配置代理,此时是Nginx服务代理请求。

解决办法如下:
nginx.conf添加以下配置解决了此问题:

location /api {
	proxy_pass http://localhost:8081;
	proxy_set_header Host $host:$server_port;
}

效果如下调用成功:
在这里插入图片描述linux详细配置:

upstream app_api {
    server 127.0.0.1:8090;
    check interval=5000 rise=1 fall=3 timeout=4000;
 }
 #react写的
server {
  listen 3000;
  server_name xxx;

  underscores_in_headers on;
  proxy_set_header Host      $host;
  proxy_set_header X-Real-IP $remote_addr;
  proxy_set_header X-Forwarded-For $remote_addr;
  proxy_set_header X-Request-ID $request_id;
  real_ip_header   X-Forwarded-For;
  client_max_body_size 20M;
  proxy_connect_timeout 300;
  #后端服务器连接的超时时间_发起握手等候响应超时时间
  proxy_read_timeout 300;
  #连接成功后_等候后端服务器响应时间_其实已经进入后端的排���之中等候处理(也可以说是后端服务器处理请求的时间)
  proxy_send_timeout 300;


# 手机端-前端页面
location / {
    alias  /home/app/nginx/html/; # 前端静态文件放置目录
    index index.html;
    try_files $uri $uri/ /index.html;
 }

 location  /api/{
    proxy_pass http://xxx:8090; 代理后端部署ip:端口
    proxy_set_header Host $host:$server_port;
   # proxy_set_header Host  $http_host;
    proxy_set_header Connection close;
    proxy_set_header X-Real-IP $remote_addr;
    proxy_set_header X-Forwarded-Server $host;
    client_max_body_size 20M;
     }
 }
 ##vue写的
server {
    listen 8091;
    server_name xxx;
    index index.php index.html index.htm;
    proxy_set_header Host $host;
    proxy_set_header X-Real-IP $remote_addr;
    proxy_set_header X-Forwarded-For $remote_addr;
    real_ip_header   X-Forwarded-For;

    location /api {
 #     proxy_pass http://nft;
       proxy_set_header Host  $http_host;
       proxy_set_header Connection close;
       proxy_set_header X-Real-IP $remote_addr;
       proxy_set_header X-Forwarded-Server $host;
       client_max_body_size 2000M;
    }

  # 运营端前端页面
  location / {
     alias /home/app/front/dist/; # 前端静态文件目录
     index index.html;
     try_files $uri $uri/ /dist/index.html;
     }
  }
  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值