Express.js控制台中未定义的地方来自哪里?

时间:2013-05-12 09:22:50

标签: node.js express undefined middleware

无用的中间件用于测试目的:

module.exports = function () {
    return function rankick(req, res, next) {
        if (Math.random() < 0.5) {
            return next('Random kick...');
        }

        next();
    };
};

注入一个简单的快递应用程序:

var express = require('express'),
    http = require('http'),
    path = require('path')
    rankick= require('./rankick'),
    util = require('util');

var app = express();

app.set('port', process.env.PORT || 8080);
app.set('views', __dirname + '/views');
app.set('view engine', 'jade');
app.use(express.favicon());
app.use(express.logger('dev'));
app.use(express.bodyParser());
app.use(express.methodOverride());
app.use(express.static(path.join(__dirname, 'public')));
app.use(rankick()); // Using the middleware

if ('development' == app.get('env')) {
  app.use(express.errorHandler());
}

app.use(function (req, res, next) {
    res.end('Hello World!');
});

http.createServer(app).listen(app.get('port'));

使用错误字符串调用next()时,控制台记录undefined后跟500错误:

undefined
GET / 500 28ms
GET / 200 4ms
undefined
GET / 500 5ms

2 个答案:

答案 0 :(得分:1)

这是errorHandler middleware中的这一行。也许它希望得到一个新的错误('随机踢......')?

我已经有一段时间以来默认使用errorHandler,所以我不是百分百肯定。如果它不是downvote,我会删除这个答案。

答案 1 :(得分:-1)

你应该做

module.exports = function rankick(req, res, next) {
    if (Math.random() < 0.5) {
        console.log('Random kick...');
    }
    else
        next();
};

不要使用return来传递函数。 module.exports是调用require时传递的对象。

如果要继续处理下一个中间件,也应该调用next()。如果您想停止处理/请求请求,请不要致电next()