0

我目前无法从我的 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;
4

1 回答 1

1

你的脚本有几个问题。首先您没有指定数据库名称,其次find是异步操作,读取异步方法的返回值不会给您结果。

var db = require('monk')('localhost:27017/dbname'); // <- database name
var medialist = db.get('media');
medialist.find({})
 .then(function(foundItems){   // <- use promise or callback to get result
   var firstFoundItem = JSON.stringify(foundItems[0]);
   console.log(firstFoundItem);
  })
于 2015-08-09T05:32:40.370 回答