Uch*_*mar 5 javascript mongoose mongodb node.js
我正在使用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)
Run Code Online (Sandbox Code Playgroud)
我的连接代码如下
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)
})
Run Code Online (Sandbox Code Playgroud)
路线代码
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();
});
});
Run Code Online (Sandbox Code Playgroud)
很好...我更改了一些内容,现在停止处理此错误。错误是它无法在mongodb客户端中声明某些功能。它需要一个功能。是否要求添加一些处理程序功能?在哪里添加那个,谢谢
handler (func) is required如果您的路由或中间件之一未定义,则 Restify 会抛出一个错误。
例如:
server.put('/foo/');
Run Code Online (Sandbox Code Playgroud)
这也会触发它:
server.put('/foo/');
Run Code Online (Sandbox Code Playgroud)
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 只是在堆栈中,因为您require('./routes')在 mongo 连接打开处理程序中运行。该错误来自您的路线文件。令人烦恼的是,mongo 的错误处理丢失了部分堆栈跟踪。如果你移动require('./routes')到 mongo 之外,它会给你正确的堆栈跟踪。