猫鼬的奇怪错误

时间:2012-12-31 18:31:31

标签: javascript node.js mongodb express mongoose

app.get('/showme', function (req, res){

    console.log(req.session.user);

     UserModel.findOne({ user: req.session.user }, function (err, user){

     if (err) throw err;

         console.log(user);
         res.send('Look');

     });

});

执行此操作时,我在终端中正确接收了用户,但在此之后,应用程序突然崩溃,这是错误TypeError: Cannot read property '_id' of nullreq.session.user已定义,并在应用中。这不是UserModel.findOne({ user: req.session.user }第一次调用,而是唯一一个返回此错误的人!为什么会这样?

编辑:

这是用户的架构

var userschema = new mongoose.Schema({

   user: String,
   pass: String,
   mail: String,
   avatar: String,

});

编辑:

我不知道为什么,但我对UserModel.find()没有任何错误。它只发生在UserModel.findOne()

编辑:

app.get('/showme', function (req, res){

  UserModel.find({ user: req.session.user }, function (err, user){ 

    for (var i = 0; i <= user[0].following.length; i++) {

       UserModel.find({ _id: user[0].following[i] }, function (err, users){

              var userss = [];
              users[i] = users[i];
              console.log(users);  

        });

     }   

 });

 res.send('Hello');

});

在此代码中,第一次UserModel不会返回任何错误,但第二次会发生错误! 这是我在终端收到的:

[ { __v: 2,
   _id: 50e1d852d7b6f9e1be000003,
   avatar: './users/rodridev/full_Mgs-solid-snake.jpg',
   user: 'rodridev',
   notification: [],
   followers: [ '50e1cfda6e63107eb6000003' ],
   following: [ '50e1cfda6e63107eb6000003' ],
  ,
  ,
  undefined ]
  [ , , , undefined ]
  [ { __v: 1,
   _id: 50e214171553600000000003,
    avatar: './users/kirbo/8816.masterchief.jpg-610x0.jpg',
    user: 'kirbo',
    followers: [ '50e1cfda6e63107eb6000003' ],
    following: [],
    imagen: [] },
 ,
 ,
 undefined ]

这就是出现此错误。与以前相同:TypeError: Cannot read property '_id' of null

1 个答案:

答案 0 :(得分:1)

尝试

UserModel.findOne({ _id: req.session.user._id }, function (err, user) {

问题是您要求的用户具有名为user的属性,其值为当前用户。你真正想要的(我假设)是数据库中当前会话用户的用户项。

或者,更好的是,我喜欢做

UserModel.findById(req.session.user._id, function (err, user) {