11

我正在使用http-proxy-middleware来实现透明代理。

我想做请求/响应检查。我的意思是,我想打印一个文本文件请求/响应,这些请求/响应通过代理而不对它们进行任何修改。

到目前为止,我使用的是类似的东西(简化版):

app.use('/proxy/:service/', proxy({
        pathRewrite: function(path, req){
            ...
        },
        router: function(req) {
            ...
        },
        onProxyRes: function(proxyRes, req, res) {
            log("Req URL: " + req.originalUrl);
            log("Response status code: " + proxyRes.statusCode);
        }
}));

log()是一个辅助函数,它使用字符串作为输入并打印它是我的日志文件)

因此,基本上我onProxyRes用来拦截响应并在那时进行记录。问题是我只能使其适用于 URL、状态代码、标头等内容,但我没有在req和/或resProxy对象中找到有效负载主体。

我已阅读有关如何将res尸体运到这里的信息。但是,这似乎是一个复杂的解决方案(需要设置一个data事件处理程序)。据我了解,它并没有覆盖req身体。

任何提示/帮助/参考都非常感谢,请。不确定是否使用onProxyRes是实现这一点的最佳方式,也许该库提供了一些功能来涵盖请求/响应情况。

4

2 回答 2

1

如果您使用最新的 express 版本,这将起作用。

app.use(express.json())
app.use('/proxy/:service/', proxy({
        onProxyRes: function(proxyRes, req, res) {
            log("Req URL: " + req.originalUrl);
            log("Response status code: " + proxyRes.statusCode);
        }
}));
于 2021-10-28T16:04:30.687 回答
0

如果你想要req.body,你必须使用一个库来获取它(或者你自己从流中构建它)。我推荐body-parser

于 2018-05-11T14:54:15.167 回答