无法使用节点js连接到数据库

时间:2013-02-22 21:42:23

标签: node.js mongodb express

我是nodejs的新手,我无法弄清楚到底发生了什么 - 我有一个基本的登录页面,当用户键入值时,我转到主页,在此之前我检查数据库是否存在该用户名。我遇到的问题是,当我点击提交按钮时,代码似乎永远不会达到数据库功能 这是app.js中的模块 -

app.post('/home',function(req,res){
        //check for user existence....
        var str;
        console.log("in home");
        user_login.perform_login(req.body.username,function(err,str){
            if(!err){
                console.log(str+" in login");
                var cookie_val=req.body.username;
                res.cookie('username',cookie_val,{signed: true});
                req.session.username=cookie_val;
                res.render('home.ejs',{
                    layout: false,
                    locals: {varname: cookie_val},
                    udata: req.session.username
                });
            }
            else{   
                console.log("Couldn't find it.");
                res.redirect("/login");
            }
        });
});

这是来自user_login.js的perform_login -

var mongo_db=require("./testdb.js");
exports.perform_login=function (username,callback){
    mongo_db.getInfo(username,function(err,bundle){
        if(!err){
            //console.log("success\n"+bundle);
            callback(false,bundle);
        }
        else{
            //console.log("couldn't find it");
            callback(true,null);
        }
    });
}

这是testdb.js -

var mongoose=require('mongoose');
mongoose.connect('mongodb://localhost/test');
exports.getInfo=function(value,callback){
    var db=mongoose.connection;
    db.on('error',console.error.bind(console,'connection error:'));
    db.once('open',function(){
        console.log("Connected!");
        var userSchema=mongoose.Schema({
            username:       String,
            password:   String
        });
        var userInstances=mongoose.model('userInstances',userSchema);
        userInstances.findOne({username: value},'username password',function(err,ui){
                                if(!err){
                                    callback(false,ui);
                                }
                                else{
                                    callback(true,"error");
                                }
                            });//findone

    });//db.once function
}//getinfo

在终端我只得到 - “在家里”,之后根本没有任何事情发生。在浏览器中,它似乎正在处理但仍留在登录页面。
当我运行带有实际硬编码值而不是req.body.username的perform_login时,立即启动app.js,我得到了正确的结果。所以我能够以某种方式在app.post()之外访问数据库 回调中有什么问题吗?

1 个答案:

答案 0 :(得分:1)

我认为你在这里做得太多了。你描述的症状是我从一个没有联系的猫鼬的经验。如果已连接,则无需管理连接和侦听事件。 Mongoose为您处理此事。您可以查询模型,并在建立连接后立即返回结果。

这是一个应该有效的例子:

app.js
//initialize mongo connection
var mongooseConnection = mongoose.connect("mongodb://localhost/test");


user.js
var mongoose = require('mongoose');
var userSchema=mongoose.Schema({
    username:       String,
    password:   String
});

userSchema.statics.performLogin = function(username, callback) {
    this.findOne({username: value},'username password',function(err,user){
    if(!err){
        callback(false,user);
    }
    else{
        callback(true,"error");
    }
});

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


route:
var User = require("./user");
app.post('/home',function(req,res){
    User.performLogin(req.body.username, function (err, user) {
        ...
    });
});