【问题标题】:Mongoose findByIdAndUpdate seems to bypass my pre "save" hook and returns stale dataMongoose findByIdAndUpdate 似乎绕过了我的预“保存”钩子并返回过时的数据
【发布时间】:2019-11-02 17:01:39
【问题描述】:

我的用户模型上有一个预“保存”钩子,用于使用 bcrypt 进行密码加密,在创建新用户记录时效果很好。但是,在编辑用户(为了简洁起见,我使用 findByIdAndUpdate)并更改密码时,它似乎绕过了该挂钩并保存为纯文本。从 Mongoose 文档中,我被引导相信任何更新事件都会调用“保存”中间件,那么为什么会发生这种情况以及如何修复它?

此外,尽管使用了 async/await,但响应仍返回 n-1 个数据。

exports.editUser = async function(req, res, next) {
  try {
    const user = await db.User.findByIdAndUpdate(req.params.id, req.body, {useFindAndModify: false}); 
    return res.status('200').json(user); 
  }
  catch(err) {
    console.log(err);
    return next({
      status: 400, 
      message: 'User could not be updated or does not exist.'
    });
  }
};

假设我们的电子邮件以“email@email.com”开头,我使用 req.body.email =“newemail@email.com”向我的编辑路由发送了一个 PUT 请求。返回的 JSON 仍然显示“电子邮件:email@email.com”。现在假设我使用 req.body.email = "thirdemail@email.com" 发送另一个 PUT 请求。返回的 JSON 现在显示“电子邮件:newemail@email.com”。

所以更新似乎正确发生,但返回的用户对象没有反映更新。鉴于使用“等待”,我的“用户”变量所代表的用户对象不应该是更新的用户记录吗?

【问题讨论】:

    标签: node.js mongodb express mongoose put


    【解决方案1】:

    好的,它绕过验证器的原因似乎已经在此处详细说明:Why Mongoose doesn't validate on update?

    我仍然不完全清楚为什么 runValidators=true 没有激活我的中间件,或者为什么返回的 User 对象不是更新版本,但无论如何我都会将此标记为完成。

    【讨论】:

      猜你喜欢
      • 2018-01-14
      • 2015-03-04
      • 2019-11-12
      • 2020-05-13
      • 2012-04-17
      • 1970-01-01
      • 1970-01-01
      • 2017-03-12
      • 1970-01-01
      相关资源
      最近更新 更多