MongoError:拓扑被破坏(在查找文档时)和实例池被破坏(在插入文档时)

sai*_*esh 2 javascript rest mongodb node.js mean-stack

我正在尝试使用Node.js,Express和Mongodb构建REST API。我正在使用mongodb npm包连接到数据库,下面是我的sever.js文件代码

var express = require("express");
var app = express();
var bodyParser = require("body-parser");
var port = process.env.PORT || 8080;
var mongo = require("mongodb");
var Server = mongo.Server;
var Db = mongo.Db;
var ObjectID = mongo.ObjectID;
try{    
    var config = require('./configure.js');
}catch(e){
    console.log("configuration file is hidden on github for security");
    config = null;
}
var usersCollection = config.usersCollection;
var login = require('./routes/login/index.js');
var signup = require('./routes/signup/index.js');
var Database = new Db(process.env.DBNAME || config.DBNAME , new Server(process.env.DBHOST || config.DBHOST, process.env.DBPORT || config.DBPORT, {'native_parser': true}));


Database.open(function (err, mongoclient) {
        if(err){
            console.log("Failed to connect to the database. Please Check the connection");
            throw err;
        }else{
            Database.authenticate(process.env.DBUSER || config.DBUSER, process.env.DBPASS || config.DBPASS, function(err, res) {
                if (err) {
                    console.log("Authentication Failed"); 
                    throw err; 
                }else{
                    console.log("Connected to the database Successfully");
                    app.use(bodyParser.urlencoded({ extended: true }));
                    app.use(bodyParser.json());
                    var users = Database.collection(usersCollection);
                    login(app,users);
                    signup(app,users);

                    Database.close();
                }
            });
        }
    });

app.listen(port,function(){
    console.log("Server Started Listening to port : "+port);
});
Run Code Online (Sandbox Code Playgroud)

路线/登录/index.js

module.exports = function(app,users){
app.route('/login')
   .post(function(req,res){
        var username = req.body.username;
        var password = req.body.password;
        var query = {'FirstName':username};

        users.find().toArray(function(err,docs){
            if(err){
                throw err;
            }else{
                console.log("no err");
                if(doc.LastName == password){
                    res.send({status : true});
                }else{
                    res.send({status : false});
                }
            }
        });
   });
Run Code Online (Sandbox Code Playgroud)

}

和路由/注册/ index.js

module.exports = function(app,users){
app.route('/signup')
   .post(function(req,res){
        var doc = { EmpNo:"1",
                    FirstName:"Andrew",
                    LastName:"Neil",
                    Age:"30",
                    Gender:"Male",
                    Skill:"MongoDB",
                    Phone:"408-1234567",
                    Email:"Andrew.Neil@gmail.com",
                    Salary:"80000"
        };

        users.insert(doc,function(err,info){
            if(err){
                throw err;
            }else{
                console.log('Successfully inserted ' + JSON.stringify(info));
                res.send({result: 'done'});
            }
        });
    });
Run Code Online (Sandbox Code Playgroud)

}

当我尝试在server.js中插入文档时,我能够成功插入它们,但是通过route / signup / index.js,如果我尝试在server.js中查找文档,则我得到的实例池也被破坏了没有错误,但是如果我尝试从routes / login / index.js进行操作,那么由于拓扑被破坏,我会收到错误消息。

需要帮助来解决它。

小智 5

如果在过程中以某种方式断开连接,则会抛出这些错误。

由于users.find()users.insert()函数都是异步的,因此server.js文件会Database.close()在完成过程之前到达该函数并关闭与数据库的连接,从而产生错误。