Как подключиться к mongodb с узлом.js (и аутентификация)?
Как мне подключиться к mongodb с узлом.Джей?
У меня есть драйвер node-mongodb-native.
там, по-видимому, 0 документации.
Это что-то вроде этого?
var mongo = require('mongodb/lib/mongodb');
var Db= new mongo.Db( dbname, new mongo.Server( 'mongolab.com', 27017, {}), {});
где я могу поместить имя пользователя и пароль?
также как мне вставить что-то?
спасибо.
13 ответов:
на источник:
после подключения:
Db.authenticate(user, password, function(err, res) { // callback });
все должны использовать эту исходную ссылку:
http://mongodb.github.com/node-mongodb-native/contents.html
ответ на вопрос:
var Db = require('mongodb').Db, MongoClient = require('mongodb').MongoClient, Server = require('mongodb').Server, ReplSetServers = require('mongodb').ReplSetServers, ObjectID = require('mongodb').ObjectID, Binary = require('mongodb').Binary, GridStore = require('mongodb').GridStore, Code = require('mongodb').Code, BSON = require('mongodb').pure().BSON, assert = require('assert'); var db = new Db('integration_tests', new Server("127.0.0.1", 27017, {auto_reconnect: false, poolSize: 4}), {w:0, native_parser: false}); // Establish connection to db db.open(function(err, db) { assert.equal(null, err); // Add a user to the database db.addUser('user', 'name', function(err, result) { assert.equal(null, err); // Authenticate db.authenticate('user', 'name', function(err, result) { assert.equal(true, result); db.close(); }); }); });
var mongo = require('mongodb'); var MongoClient = mongo.MongoClient; MongoClient.connect('mongodb://'+DATABASEUSERNAME+':'+DATABASEPASSWORD+'@'+DATABASEHOST+':'DATABASEPORT+'/'+DATABASENAME,function(err, db){ if(err) console.log(err); else { console.log('Mongo Conn....'); } }); //for local server //in local server DBPASSWOAD and DBusername not required MongoClient.connect('mongodb://'+DATABASEHOST+':'+DATABASEPORT+'/'+DATABASENAME,function(err, db){ if(err) console.log(err); else { console.log('Mongo Conn....'); } });
Я нахожу использование url-адреса Mongo удобным. Я сохраняю URL-адрес в переменной среды и использую его для настройки серверов, в то время как версия разработки использует url-адрес по умолчанию без пароля.
URL имеет вид:
export MONGODB_DATABASE_URL=mongodb://USERNAME:PASSWORD@DBHOST:DBPORT/DBNAME
код для подключения таким образом:
var DATABASE_URL = process.env.MONGODB_DATABASE_URL || mongodb.DEFAULT_URL; mongo_connect(DATABASE_URL, mongodb_server_options, function(err, db) { if(db && !err) { console.log("connected to mongodb" + " " + lobby_db); } else if(err) { console.log("NOT connected to mongodb " + err + " " + lobby_db); } });
мой вариант:
var MongoClient = require('mongodb').MongoClient; MongoClient.connect('mongodb://user:pass@dhost:port/baseName', function(err, db) { if (err) { console.error(err); } var collection = db.collection('collectionName'); collection.find().toArray(function(err, docs) { console.log(docs); }); });
рекомендую mongoskin Я только что создал.
var mongo = require('mongoskin'); var db = mongo.db('admin:pass@localhost/mydb?auto_reconnnect'); db.collection('mycollection').find().toArray(function(err, items){ // do something with items });
это mongoskin синхронизации? Нет, это асинхронно.
Если у вас по-прежнему есть проблемы с родным драйвером, вы также можете проверить сонный Мангуст. Это сервер Python REST, к которому вы можете просто получить доступ с запросом узла, чтобы добраться до вашего экземпляра Mongo. http://www.snailinaturtleneck.com/blog/2010/02/22/sleepy-mongoose-a-mongodb-rest-interface/
со ссылкой, предоставленной @mattdlockyer в качестве ссылки, это сработало для меня:
var mongo = require('mongodb'); var server = new mongo.Server(host, port, options); db = new mongo.Db(mydb, server, {fsync:true}); db.open(function(err, db) { if(!err) { console.log("Connected to database"); db.authenticate(user, password, function(err, res) { if(!err) { console.log("Authenticated"); } else { console.log("Error in authentication."); console.log(err); } }); } else { console.log("Error in open()."); console.log(err); }; }); exports.testMongo = function(req, res){ db.collection( mycollection, function(err, collection) { collection.find().toArray(function(err, items) { res.send(items); }); }); };
небольшая опечатка с ответом Криса.
Db.authenticate(user, password, function({ // callback }));
должно быть
Db.authenticate(user, password, function(){ // callback } );
также в зависимости от конфигурации mongodb вам может потребоваться сначала подключиться к admin и auth, прежде чем перейти к другой базе данных. Это произойдет, если вы не добавите пользователя в базу данных, к которой вы пытаетесь получить доступ. Затем вы можете аутентифицировать через admin, а затем переключить db, а затем читать или писать по желанию.
вот новый май для аутентификации от "admin" , а затем переключиться на нужную БД для дальнейших операций:
var MongoClient = require('mongodb').MongoClient; var Db = require('mongodb').Db, Server = require('mongodb').Server , assert = require('assert'); var user = 'user'; var password = 'password'; MongoClient.connect('mongodb://'+user+':'+password+'@localhost:27017/opsdb',{native_parser:true, authSource:'admin'}, function(err,db){ if(err){ console.log("Auth Failed"); return; } console.log("Connected"); db.collection("cols").find({loc:{ $eq: null } }, function(err, docs) { docs.each(function(err, doc) { if(doc) { console.log(doc['_id']); } }); }); db.close(); });
Я использую Мангуст для подключения к mongodb. Установите Mongoose npm, используя следующую команду
npm установить Мангуст
var mongoose = require('mongoose'); mongoose.connect('mongodb://localhost:27017/database_name', function(err){ if(err){ console.log('database not connected'); } }); var Schema = mongoose.Schema; var userschema = new Schema ({}); var user = mongoose.model('collection_name', userschema);
мы можем использовать такие запросы
user.find({},function(err,data){ if(err){ console.log(err); } console.log(data); });