使用nodejs和Monk进行Mongodb身份验证

时间:2016-09-09 00:07:03

标签: node.js mongodb express monk

我在尝试查询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 }

2 个答案:

答案 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');