gpt4 book ai didi

node.js - 声明多个模式后无法从数据库中获取数据(mongoose + express + mongodb

转载 作者:IT老高 更新时间:2023-10-28 13:09:03 27 4
gpt4 key购买 nike

我是 node.js 的新手,我在访问声明多个 mongoose 模式时遇到问题。

//模型中的schema.js

var mongoose = require('mongoose');
var Schema = mongoose.Schema
, ObjectId = Schema.ObjectId;

//User Schema
var userSchema = new Schema({
id: ObjectId,
firstname: {type: String, require: true},
lastname: {type: String, require: true},
username: {type: String, unique: true, require: true},
password: {type: String, require: true},
role: {type: [String], require: true}
})

var User = mongoose.model('User', userSchema);
module.exports = User;

//Question Schema
var qnSchema = new Schema({
id: ObjectId,
question: {type: String, require: true},
module_id: {type: ObjectId, ref: 'Module'}
})

var Question = mongoose.model('Question', qnSchema);
module.exports = Question;

//Answer Schema
var ansSchema = new Schema({
id: ObjectId,
answer: String,
question: {type: ObjectId, ref: 'Question'}
})

var Answer = mongoose.model('Answer', ansSchema);
module.exports = Answer;

//Module Schema
var modSchema = new Schema({
id: ObjectId,
name: {type: String, require: true}
})

var Module = mongoose.model('Module', modSchema);
module.exports = Module;

//Role Schema
var roleSchema = new Schema({
id: ObjectId,
role: {type: String, require: true}
})

var Role = mongoose.model('Role', roleSchema);
module.exports = Role;

// Controller 中的index.js

var mongoose = require('mongoose');
var User = require('../models/schema');
var db = mongoose.connect('mongodb://localhost/damai');

module.exports = function(app) {

app.get('/', function(req, res) {
if (typeof req.session.userid == 'undefined') {
res.render('login', { title: app.get('title') });
} else {
res.render('index', { title: app.get('title') });
}
});

app.post('/login', function(req, res) {
passwordVerification(req, res);
});
}

function passwordVerification(req, res)
{
var userid = req.param('userid');
var password = req.param('password');
User.findOne({'username': userid},{'password': 1}, function(err, cb)
{
console.log(cb);
if(cb!= null)
{
if (password == cb.password) {
req.session.userid = userid;
res.render('index', { title: app.get('title'), 'userid': userid });
} else {
res.render('login', { title: app.get('title'), error: 'Invalid login'});
}
}
else
{
res.render('login', { title: app.get('title'), error: 'Invalid login'});
}
});
}

当我的 schema.js 中只有“用户架构”时,来自 index.js 的方法“passwordVerification()”的数据库调用将返回从数据库中检索到的相关密码。但是,当我开始在 schema.js 中添加其他架构(例如“问题架构”)时,“passwordVerification()”方法将始终返回 null。

最佳答案

当像在 schema.js 中那样从单个文件中导出多个模型时,您需要为每个导出的模型指定其自己的 exports 字段名称。

例如,将 schema.js 中的多个 module.exports = ... 行替换为导出所有模型的文件末尾的以下代码:

module.exports = {
User: User,
Question: Question,
Answer: Answer,
Module: Module,
Role: Role
};

然后在 index.js 中你可以像这样访问模型:

var models = require('./schema');
...
models.User.findOne(...

关于node.js - 声明多个模式后无法从数据库中获取数据(mongoose + express + mongodb,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13857203/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com