gpt4 book ai didi

Node.Js/Express - 输出响应的前几个字符的简单中间件

转载 作者:搜寻专家 更新时间:2023-10-31 23:10:11 24 4
gpt4 key购买 nike

对于日志记录/调试,我想在响应发送到浏览器之前输出前一百个左右的字符。我可以使用中间件和响应对象做一些简单的事情吗?

理想情况下是这样的:

app.use(function(req, res, next) {
console.log('Response snippet: '+((res.body || '').substr(0,100)));
next();
});

除了响应没有正文,我不太清楚要发回的当前正文传递到哪里。

更新:

Peter 的回答奏效了,我想我应该将我的中间件代码放在这里以节省 future 查看者的点击次数:

App.use(function(req, res, next) {
var end = res.end;
res.end = function(chunk, encoding){
res.end = end;
if (chunk) {
console.log(chunk);
}
res.end(chunk, encoding);
};
next();
});

最佳答案

因此您需要挂接到响应输出 API,这在中间件中不像挂接到请求处理那样简单。最好的例子是 connect's built-in logger middleware .它基本上是猴子修补 req.end 方法并将该数据转发到它的流,然后继续调用真正的 req.end 函数。您需要遵循这种模式,它应该适用于非流式响应。

该模式可能最终只为您提供最后一 block 数据(对于流式响应的情况)。如果是这样,您只需要猴子修补 res.write 而不是 res.end 就可以访问第一个 block 。一旦你记录了第一个 block ,只需 un-monkey-patch res.write

关于Node.Js/Express - 输出响应的前几个字符的简单中间件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13690335/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com