我目前无法从我的 mongodb 集合“媒体”中获取任何具有属性“标题”和“作者”的内容(其中包括,但为了说明目的,这只是两个)。以下代码打印“未定义到控制台”。
var db = require('monk')(config['dbPath']);
var medialist = db.get('media');
var foundItems = medialist.find();
var firstFoundItem = JSON.stringify(foundItems[0]);
console.log(firstFoundItem);
此外,当服务器启动时,我在控制台中收到以下消息:
“{ [错误:找不到模块'../build/Release/bson'] code'MODULE_NOT_FOUND'} js-bson:使用纯JS版本加载c ++ bson扩展失败”
在 Google 上搜索该错误消息后,我尝试了一些解决方案,包括安装 npm bson。只是我的代码不起作用,还是缺少模块(或两者兼而有之)?
谢谢,
音乐
编辑:按照@hassansin 对异步调用的建议,我尝试了以下操作,现在给了我“无法在 e:\Dev\BookWyrm\api\userRouter.js:16:43 读取未定义的属性 'then'
var err;
var params = req.params;
mongoHandler.getMedia(err, params)
.then(function(itemList) {
if (!err) {
var firstFoundItem = JSON.stringify(itemList[0]);
console.log(firstFoundItem);
res.sendFile('medialist.html', {
root: './public/views/'
});
} else {
res.sendFile('errorpage.html', {
root: './public/views/'
});
}
});
});
mongoHandler 是以下模块:
var config = require('../config.json');
//var db = require('monk')('localhost:27017/bookwyrm');
var mongo = require('mongodb');
var server = new mongo.Server('localhost', 27017, {
auto_reconnect: true
});
var db = new mongo.Db('bookwyrm', server);
function getMedia(err, params) {
var callback = {};
asyncGet(err, callback);
if (!err) {
return callback.items;
} else {
console.log("Connection or query to mongodb failed");
}
}
function asyncGet(err, callback) {
db.open(function(err, db) {
if (!err) {
db.collection('media', function(err, collection) {
if (!err) {
collection.find(params).toArray(function(err, items) {
if (!err) {
db.close();
callback.items = items;
} else {
errorHandler(err, callback);
}
})
} else {
errorHandler(err, callback);
}
})
} else {
errorHandler(err, callback);
}
});
}
function errorHandler(err, callback) {
if (!db) {
db.close()
};
callback.err = err;
}
module.exports.getMedia = getMedia;