AssertionError [ERR_ASSERTION]:mongodb中需要handler(func)

时间:2018-05-15 04:49:23

标签: javascript node.js mongodb mongoose

我正在使用mongooose连接mongodb,但我收到了以下错误

/Users/uchitkumar/api/node_modules/mongodb/lib/mongo_client.js:804
          throw err;
          ^

AssertionError [ERR_ASSERTION]: handler (func) is required
    at new AssertionError (internal/errors.js:315:11)
    at _toss (/Users/uchitkumar/api/node_modules/assert-plus/assert.js:22:11)
    at Function.out.(anonymous function) [as func] (/Users/uchitkumar/api/node_modules/assert-plus/assert.js:122:17)
    at process (/Users/uchitkumar/api/node_modules/restify/lib/server.js:1352:20)
    at argumentsToChain (/Users/uchitkumar/api/node_modules/restify/lib/server.js:1361:12)
    at Server.serverMethod [as put] (/Users/uchitkumar/api/node_modules/restify/lib/server.js:1475:21)

我的连接代码如下

server.listen(config.port, function() {

    mongoose.connection.on('error', function(err) {
        console.log('Mongoose default connection error: ' + err)
        process.exit(1)
    })

    mongoose.connection.on('open', function(err) {

        if (err) {
            console.log('Mongoose default connection error: ' + err)
            process.exit(1)
        }

        console.log(
            '%s v%s ready to accept connections on port %s in %s environment.',
            server.name,
            config.version,
            config.port,
            config.env
        )

        require('./routes')

    })

    global.db = mongoose.connect(config.db.uri)

})

路线代码

server.get('/', function indexHTML(req, res, next) {
    fs.readFile(__dirname + '/../index.html', function (err, data) {
        if (err) {
            next(err);
            return;
        }

        res.setHeader('Content-Type', 'text/html');
        res.writeHead(200);
        res.end(data);
        next();
    });
});

这很好......我改变了一些东西,现在它停止了这个错误。错误是它无法在mongodb客户端中断言某些函数。它需要一个功能。是否要求添加一些处理函数?在哪里添加 提前谢谢

1 个答案:

答案 0 :(得分:0)

handler (func) is required是重新定义(如果您的路由或中间件之一未定义)引发的错误。

例如:

server.put('/foo/');

这也会触发它:

var myMidelware = undefined; // todo: define this

app.put('/route', myMiddleware, (req, res) => { /* todo: handle req */ })

当它试图验证handler (func) is required是一个函数时,将抛出错误myMidelware

在您发布的路线代码中没有看到此消息,但我认为这是某种原因。您是否在某处定义了PUT方法?

(同样的错误也会发生在server.get(),server.post()等上,但是堆栈跟踪中的[as put]表示它在server.put()调用上令人窒息。)

请参见https://github.com/restify/node-restify/blob/v7.2.1/lib/server.js#L1386

此外,我不认为该错误与mongodb有关; mongo只是在堆栈中,因为您在mongo连接打开处理程序中运行了require('./routes')。错误来自您的路由文件。令人讨厌的是,mongo的错误处理失去了堆栈跟踪的一部分。如果将require('./routes')移到mongo内容之外,它将为您提供正确的堆栈跟踪。