Mongoskin не будет получать некоторые результаты от mongodb в приложении nodejs
Я хотел прочитать некоторые данные из mongodb через mongoskin. Но nodejs выдает мне ошибку, когда я пытаюсь вызвать localhost:3000/tasks
В моей базе данных 'todo' есть несколько элементов в коллекции 'tasks'. Результат в консоли работает нормально, когда я запускаю приложение.
Кто-нибудь может увидеть, где я написал что-то не так?
Eroor сообщение:
500 TypeError: Cannot read property 'tasks' of undefined
at exports.list (/Users/piet/Websites/privat/mongo/routes/tasks.js:7:8) at callbacks (/Users/piet/Websites/privat/mongo/node_modules/express/lib/router/index.js:164:37)
at param (/Users/piet/Websites/privat/mongo/node_modules/express/lib/router/index.js:138:11)
at pass (/Users/piet/Websites/privat/mongo/node_modules/express/lib/router/index.js:145:5)
at Router._dispatch (/Users/piet/Websites/privat/mongo/node_modules/express/lib/router/index.js:173:5)
at Object.router (/Users/piet/Websites/privat/mongo/node_modules/express/lib/router/index.js:33:10)
at next (/Users/piet/Websites/privat/mongo/node_modules/express/node_modules/connect/lib/proto.js:193: 15)
at Object.methodOverride [as handle] (/Users/piet/Websites/privat/mongo/node_modules/express/node_modules/connect/lib/middleware/me thodOverride.js:48:5)
at next (/Users/piet/Websites/privat/mongo/node_modules/express/node_modules/connect/lib/proto.js:193: 15)
at Object.urlencoded [as handle] (/Users/piet/Websites/privat/mongo/node_modules/express/node_modules/connect/lib/middleware/ur lencoded.js:49:37)
Мой app.js:
var express = require('express');
var routes = require('./routes');
var tasks = require('./routes/tasks');
var http = require('http');
var path = require('path');
var mongo = require("mongoskin");
var db = mongo.db('localhost:27017/todo?auto_reconnect=true', {
safe:true })
.collection('tasks')
.find()
.toArray(function(error, items){
console.log(items);
})
var app = express();
app.set('port', process.env.PORT || 3000);
app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'jade');
app.use(express.favicon());
app.use(express.logger('dev'));
app.use(express.json());
app.use(express.urlencoded());
app.use(express.methodOverride());
app.use(app.router);
app.use(express.static(path.join(__dirname, 'public')));
if ('development' == app.get('env')) {
app.use(express.errorHandler());
}
app.get('/', routes.index);
app.get('/tasks', tasks.list);
http.createServer(app).listen(app.get('port'), function(){
console.log('Express server listening on port ' + app.get('port'));
});
Файл маршрута в /routes/tasks.js
exports.list = function(req, res, next){
req.db.tasks.find({
completed: false
}).toArray(function(error, tasks){
res.render('tasks', {
title: "ToDo list",
name: tasks = tasks || []
})
})
};
3 ответа
Вам понадобится промежуточное программное обеспечение для подключения объекта коллекции к вашим запросам:
var db = mongo.db('localhost:27017/todo?auto_reconnect=true');
var tasks = db.collection('tasks');
...
app.use(function(req, res, next) {
req.db = { tasks : tasks }; // this exposes the collection as `req.db.tasks`
// to your route handlers
next();
});
app.use(app.router);
...
Используйте 28017 в качестве идентификатора порта. Вы можете проверить, что вы получаете в "req.db". Mayb это не определено.
В вашем маршруте /task.js req является объектом запроса Express.js. У него нет дескриптора "db", поэтому вы получаете ошибку:
500 TypeError: Cannot read property 'tasks' of undefined
В app.js это неправильный способ получить дескриптор db:
var mongo = require("mongoskin");
var db = mongo.db('localhost:27017/todo?auto_reconnect=true', { safe:true })
.collection('tasks')
.find()
.toArray(function(error, items){
console.log(items);
});
Код БД должен быть перемещен в отдельный модуль (например, dbConnection.js), так что каждый раз, когда вам нужен дескриптор БД, вам просто нужно сделать это:
var db = require('./dbConnection').getDb();
routs/task.js должен получить дескриптор базы данных для вызова базы данных. Итак, вот ваши исправленные файлы app.js, routs/task.js и новые файлы dbConnection.js:
dbConnection.js:
var open = function() {
return require('mongoskin').db('localhost:27017/todo?auto_reconnect=true',
{safe: true, strict: false}
);
};
var db = open();
var dbConnection = {
getDb: function() {
if (!db) {
db = open();
}
return db;
}
};
module.exports = dbConnection;
маршруты /task.js:
var db = require('../dbConnection').getDb();
exports.list = function(req, res, next){
var tasksCollection = db.collection('tasks');
tasksCollection.find({ completed: false }).toArray(function(error, tasks){
res.render('tasks', {
title: "ToDo list",
name: (tasks || [])
});
});
};
app.js:
var express = require('express');
var routes = require('./routes');
var tasks = require('./routes/tasks');
var http = require('http');
var path = require('path');
var app = express();
app.set('port', process.env.PORT || 3000);
app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'jade');
app.use(express.favicon());
app.use(express.logger('dev'));
app.use(express.json());
app.use(express.urlencoded());
app.use(express.methodOverride());
app.use(app.router);
app.use(express.static(path.join(__dirname, 'public')));
if ('development' == app.get('env')) {
app.use(express.errorHandler());
}
app.get('/', routes.index);
app.get('/tasks', tasks.list);
http.createServer(app).listen(app.get('port'), function(){
console.log('Express server listening on port ' + app.get('port'));
});