Mongoose没有将更新的文档保存到数据库

时间:2013-10-04 18:45:44

标签: javascript node.js mongodb mongoose

编辑:之前曾问过这个问题,但我并没有很好地提出这个问题。我改写了这个问题。在此先感谢您的帮助!

我正在为学校项目编写一个简单的消息服务器。在其他功能中,服务器允许用户更新其帐户中存储的信息。当用户更新其帐户时,将为其生成身份验证令牌。这是定义所有这些的模式。请注意,headerbody是用户输入的一部分:

UserSchema = new Schema({
  _id: {type: ObjectId, select: false},
  username: {type: String, required: true, index: {unique: true} },
  password: {type: String, required: true, select: false},
  email: {type: String},
  token: {type: String, select: false}
}, {
  autoIndex: false 
});
UserSchema.pre("save", function(next) {
  // Create a new token for the user
  var self = this;

  bcrypt.genSalt(SALT_WORK_FACTOR, function(err, salt) {
    if (err) {
      next(err);
    } else {
      crypto.randomBytes(256, function(err, bytes) {
        if (err) {
          next(err);
        } else {
          bytes = bytes.toString("hex");
          bcrypt.hash((new Date() + bytes), salt, function(err, tokenHash) {
            if (err) {
              next(err);
            } else {
              self.token = tokenHash;
              next();
            }
          });
        }
      });
    }
  });
});
UserSchema.pre("save", function(next) {
  // Hash the password before saving
  var self = this;
  if (!self.isModified("password")) {
    next();
  } else {
    bcrypt.genSalt(SALT_WORK_FACTOR, function(err, salt) {
      if (err) {
        next(err);
      } else {      
        bcrypt.hash(self.password, salt, function(err, passwordHash) {
          if (err) {
            next(err);
          } else {
            self.password = passwordHash;
            next();
          }
        });
      }
    });
  }
});

我在更新特定用户时遇到了问题。因为我想使用Model中间件,所以我更新用户的方式是使用Model#findOne()后跟Model#save()。这是我必须做的代码:

// Make sure user provided all necessary information.
if (!header.token) {
  return callback(new errors.MissingHeaderDataError("Missing 'token' parameter in the header."));
} else {
  // Update the user account based on what's in the envelope's body.
  User.findOne({"token": header.token}, "+token +password", function (err, user) {
    if (err) {
      return callback(err);
    } else {
      // Get a list of all parameters the user wants to change.
     var paramsToChange = Object.keys(body);

     // Now update the parameters
      paramsToChange.forEach(function(param) {
        user[param] = body[param];
     });
      console.log("Updated user:");
      console.dir(user);
      user.save(function(err, user) {
        if (err) {
          return callback(err);
        } else {
          console.log("Returned user:");
          console.dir(user);
          User.find({}, "+token +password", function(err, foundUser) {
            if (err) {
              throw err;
            } else {
              console.log(JSON.stringify(foundUser));
            }
          });
          callback(null, new SuccessEnvelope(user));
        }
      });
    }
  });
}

当我运行我的测试并得到最后一段代码时(在返回save()之后),我得到了这个输出:

Updated user:
{ token: '$2a$10$5VWWqjJ52aGbS4xc6NDKjuGPv8brX7pRmwiKyYjP8VHoTKCtYZiTu',
  username: 'jim_bob',
  password: '$2a$10$ue08HUsunzzzcbZURzXF7uaH1dZxF3SwkwadC6D1JsIC9xAUhTbCC',
  email: 'joe_bob@email.com',
  __v: 0 }
Returned user:
{ token: '$2a$10$fRwED..7fFFhN46Vn.ZJW..xYql5t5P39LHddjFS4kl/pmhwfT.tO',
  username: 'jim_bob',
  password: '$2a$10$ue08HUsunzzzcbZURzXF7uaH1dZxF3SwkwadC6D1JsIC9xAUhTbCC',
  email: 'joe_bob@email.com',
  __v: 0 }
[{"token":"$2a$10$5VWWqjJ52aGbS4xc6NDKjuGPv8brX7pRmwiKyYjP8VHoTKCtYZiTu","username":"joe_bob","password":"$2a$10$ue08HUsunzzzcbZURzXF7uaH1dZ
xF3SwkwadC6D1JsIC9xAUhTbCC","email":"joe_bob@email.com","__v":0}]

如您所见,文档未正确保存到数据库中,因为之前的数据仍然存在。我的问题是:为什么? 为什么用户在调用save时没有更新?我认为我正在做的一切正常,但显然我不是。任何有关这方面的帮助都会很棒,因为我疯了!

1 个答案:

答案 0 :(得分:3)

显然,为了将文档保存到数据库,它需要_id。有点傻,Mongoose在找不到文件时不会出错。唉...

我更新了我的代码以反映更改:

 // Make sure user provided all necessary information.
  if (!header.token) {
    return callback(new errors.MissingHeaderDataError("Missing 'token' parameter in the header."));
  } else {
    // Update the user account based on what's in the envelope's body.
    User.findOne({"token": header.token}, "+_id +token +password", function (err, user) {
      if (err) {
        return callback(err);
      } else {
        console.log("Found user:");
        console.dir(user);
        // Get a list of all parameters the user wants to change.
        var paramsToChange = Object.keys(body);

        // Now update the parameters
        paramsToChange.forEach(function(param) {
          user[param] = body[param];
        });
        console.log("Updated user:");
        console.dir(user);
        user.save(function(err, user, numberTouched) {
          if (err) {
            return callback(err);
          } else {
            console.log("Returned user:");
            console.dir(user);
            console.log(numberTouched);
            User.find({}, "+token +password", function(err, foundUser) {
              if (err) {
                throw err;
              } else {
                console.dir(foundUser);
              }
            });
            callback(null, new SuccessEnvelope(user));
          }
        });
      }
    });
  }