MongoDB第一次不会返回正确的数据

时间:2016-03-27 19:28:52

标签: javascript jquery node.js mongodb mongoose

这是我的代码:

// Modules
var mongodb = require('mongodb');
var MongoClient = mongodb.MongoClient;
var url = 'mongodb://localhost:27017/affinity';
window.$ = window.jQuery = require('jquery');
var user_data;

$(document).ready(function () {

   // Look through db for user
   // Flters through the db to find the user and their password to authenticate them in.
  userInfo = function (db, callback) {
  var username = $('#username').val();
  var password = $('#password').val();
  var users = db.collection('users');

  // Searches through each user in the db to find one which meets conitions.
  var cursor = users.find({
     "username": username
  }, {"limit": 1} ).each(function (err, doc) {
     if (doc != null) {
        if (doc.password === password) {
           user_data = doc;
            //window.location.replace(__dirname + '/assets/views/main.html');
         } else {
            $("#error-hint").css(
               'visibility', 'visible'
            );
         }
      } else {
         // Skip user if it isn't matching
      }
   });
   console.log(user_data);
}

// Connects to database.
// Inserts all user data to the database.
MongoClient.connect(url, function (err, db) {
   if (err) {
      console.log('Couldn\'t connect to the mongoDB server. \nERROR: ' + err);
   } else {
      var collection = db.collection('users');

      // When login button run authUser function
      $('#auth-btn').click(function () {
         userInfo(db, function () {
            db.close();
         });
      });
   }
});


 });

问题在于,当我点击按钮以使用正确的信息对用户进行身份验证时,它会返回一个未定义的值'但如果我第二次按下按钮,它就不会改变任何东西,它会从数据库中返回正确的数据。我希望它显示第一次正确验证用户身份。我做错了什么?请帮忙。

1 个答案:

答案 0 :(得分:0)

您的意思是console.log(user_data);会返回undefined数据吗?

那是因为你没有在回调中调用它,所以第一次调用console.log(user_data);时,db查询没有找到用户。当您第二次调用它时,第一次数据库查询已完成,因此已设置user_data,因此它将打印给您。第二次按登录按钮时尝试查找其他用户。它将打印第一个用户的数据。

请注意,您的通话是异步的!因此,为了在查询完成时查看查询结果,只需将console.log(user_data);传递回each中的回调函数。

此外,如果您想将结果集限制为仅使用一个元素,请使用db.collection.fidnOne({...})代替db.collection.find({...},{limit...}).each(...)