如何使用http-proxy-middleware和express通过请求主机名设置代理?

5

我想使用http-proxy-middleware和express来配置代理。 规则是主机名的映射,例如:

http://123.com   >>  http://localhost:3000/123
http://456.com   >>  http://localhost:3000/abc

我试过这样做:
import express from 'express';
import http from 'http';
import proxy from 'http-proxy-middleware';

const app = express();

app.use( async function (req, res) {  
  let direction = 'http://localhost:3000';
  console.log('hostname: ', req.hostname);
  console.log('originalUrl: ', req.originalUrl);
  if (req.hostname == '123.com') {
    direction = `http://localhost:3000/123${req.originalUrl}`;
  }
  if (req.hostname == '456.com') {
    direction = `http://localhost:3000/abc${req.originalUrl}`;
  }

  return await proxy({ target: direction, changeOrigin: false })
});

const server = http.createServer(app);
app.set('port', '127.0.0.1');
server.listen(9999, '0.0.0.0');

但它没有起作用。

1个回答

8

你需要考虑以下几点:

  • http-proxy-middleware 模块不会返回一个 Promise,而是返回一个 express middleware。
  • 你可以使用自定义过滤器来决定是否代理请求。
  • 你需要添加 pathRewrite 选项,以便根据当前的主机名重写 url。
  • 另一个选项是使用路由器选项。请参阅相关文档

我编写了一个快速的 express 应用程序来测试这个问题(请注意,我用 localwebapplocalwebapp2 覆盖了我的 hosts 文件,并将它们指向 127.0.0.1),它似乎工作正常:

const express = require('express')
const proxy = require('http-proxy-middleware')

const app = express();
const filter = (pathname, req) => {
    if (req.hostname == 'localwebapp' || req.hostname == 'localwebapp2') {
        return true;
    }
    return false;
};

app.get('/123*', (req, res) => {
    res.send(`matched 123* route: ${req.path}`);
})

app.get('/abc*', (req, res) => {
    res.send(`matched abc* route: ${req.path}`);
})

app.get('/test', (req, res) => {
    res.send("matched non proxied route '/test'");
})

const apiProxy = proxy(filter, {
    target: 'http://localhost:3000',
    logLevel: 'debug',
    changeOrigin: true,
    pathRewrite: function (path, req) {
        if (req.hostname == 'localwebapp') {
            return `/123${req.originalUrl}`;
        }
        if (req.hostname == 'localwebapp2') {
            return `/abc${req.originalUrl}`;
        }
        return path;
    }
})
app.use(apiProxy)
app.listen(3000);

2
如何更改Referer头? - Rife

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接