我在我的Nodejitsu/MongoHQ应用程序中用MongoDB保存文档时遇到了问题。在本地,一切都很好,但是shell db需要身份验证,并且使用工作的user/pass失败(使用相同的凭据连接到MongoDB MongoHQ工作正常)。下面是函数:
var update_user = function(user, callback) {
var client = new Db(db, new Server(host, port, {}));
var update = function (err, collection) {
collection.findOne({uid:user.id}, function(err, doc) {
if (err) { throw err; }
if (!doc) doc = { uid: user.id }
doc.img = user.img;
doc.name = user.name;
collection.save(doc, {safe: true}, function(err, doc) {
if (err) { throw err; }
callback(user);
});
});
};
client.open(function(err, client) {
if (err) { throw err; }
client.authenticate(user, pass, function(err, result) {
client.collection('users', update);
});
});
}我到底做错了什么?
UPD: authenticate方法的err参数具有下列值:
{ [MongoError: auth fails] name: 'MongoError', errmsg: 'auth fails', ok: 0 }我再次检查了存储的密码和用户名,它们可以在MongoHQ外壳中登录。
发布于 2012-09-17 02:26:27
如果您的凭据用于管理员用户帐户,则在authenticate调用中对管理员数据库执行must target操作:
client.authenticate(user, pass, {authdb: 'admin'}, function(err, result) {
client.collection('users', update);
});https://stackoverflow.com/questions/12445054
复制相似问题