我在尝试查询mongodb上的一个集合时出现错误,该集合已经(似乎)成功连接到我的app.js
文件中。
var mongo = require('mongodb');
var monk = require('monk');
var db = monk('mongodb://USERNAME:PASSWORD@localhost:27017/test_db');
var app = express();
// Make our db accessible to our router
app.use(function(req,res,next){
req.db = db;
next();
});
它连接然后在我的路由器文件中:
/* users.js*/
router.post('/login', function(req, res, next) {
var params = req.body;
var userid = params.userid;
var pw = params.password
var db = req.db;
var userdb = db.get('users');
userdb.findOne({'userid' : userid}, function(e,user) {
if (e) {
console.log("error reading user doc ->");
console.log(e);
return;
} else {
....
}
});
});
查询集合后出现以下错误:
{ [MongoError: auth failed] name: 'MongoError', ok: 0, errmsg: 'auth failed', code: 18 }
答案 0 :(得分:3)
查看MongoDB文档中的选项:
http://mongodb.github.io/node-mongodb-native/2.1/reference/connecting/connection-settings/
您会注意到用户名和密码不是有效选项。如果您要连接到test_db并且您的root用户位于另一个数据库(比如说admin),那么您应该使用authSource:admin。您的连接字符串将如下所示:
var db = monk('user:pass@localhost:27017/test_db',{authSource:'admin'});
当我尝试连接到我的数据库但我的auth用户在另一个用户时,这让我感到困惑。
希望它有所帮助!
答案 1 :(得分:1)
var db = monk('localhost:27017/test_db', {
username : 'USERNAME',
password : 'PASSWORD'
});
or
var db = monk('USERNAME:PASSWORD@localhost:27017/test_db');