Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/javascript/381.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/node.js/40.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Javascript express.js显式结束响应时调用的下一个中间件层_Javascript_Node.js_Express - Fatal编程技术网

Javascript express.js显式结束响应时调用的下一个中间件层

Javascript express.js显式结束响应时调用的下一个中间件层,javascript,node.js,express,Javascript,Node.js,Express,我遇到了以下行为: 当我安装了多个express中间件时,请求将继续级联到下一个中间件,即使我在上一个中间件中使用res.json()明确结束请求。还要注意,我并没有在上述中间件的任何地方调用next() app.use('/v1/status', function (req, res, next) { res.json({ status: 'ok' }); }); app.use(function (req, res, next) { console.log('I alway

我遇到了以下行为:

当我安装了多个express中间件时,请求将继续级联到下一个中间件,即使我在上一个中间件中使用
res.json()
明确结束请求。还要注意,我并没有在上述中间件的任何地方调用
next()

app.use('/v1/status', function (req, res, next) {
    res.json({ status: 'ok' });
});

app.use(function (req, res, next) {
    console.log('I always get called');
});
这是“新”的行为吗?因为据我的理解(以及4x文档),这不应该发生

任何帮助都将不胜感激


MacOSX上的express v4.13.0,因此我在惊人的@dougwilson的帮助下发现了这个问题。他建议我打印被请求的url,在那里我看到正在打印
/favicon.ico

仔细检查后,我发现第一个中间件实际上完成了请求,但favicon请求仍然挂起。这就是第二个中间件被调用的原因。这与
res.json()
工作不正常无关


以前从未遇到过这个问题,这让我抓狂!谢谢大家的帮助

res.json不会结束流。您应该使用return结束flow@Akshat-返回不起作用。据我所知,
app.use
语句即使在发送
res.json
后也会继续执行。不过很奇怪。即使在发送响应后使用
res.end()
,也会发生同样的情况。如果尝试了,则很遗憾无法工作。但这甚至不必要,因为
res.json()
res.send()
相同,后者又与
res.end()
@danillouz相同-我想,尝试使用
require('express').Router()
而不是
app
@danillouz,如果不希望每次都调用该函数,则必须删除该函数。在中间件中定义两个不同的函数,根据错误/成功条件调用它们