微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

带有 bcrypt 迁移的 MongoDB

如何解决带有 bcrypt 迁移的 MongoDB

我正在尝试对我的用户集合中的所有密码进行哈希处理。

我使用 mongoose 和 bcrypt 创建了一个节点脚本,该脚本获取所有用户,然后对每个用户进行哈希处理。

我当前的代码如下:

    users = getAllUsers()
    foreach user
        hash = bcrypt user password
        user.updatePassword(hash)

我的问题是有一种方法可以通过 1 个 updateMany() 调用来完成此操作。

有点像……

users.updateMany(
    {},==> get all of the users
    { $set: { password: bcrypt.hash(password) } } ==> for each user,set their password to their encrypted password
)

我之所以这么问是因为我知道 MongoDB 对它在一次调用中可以提取的数据量有限制。将所有用户调用一个局部变量中似乎是对内存的滥用。我宁愿只给 mongo 工具,然后让 mongo 处理更新。

这可能吗?我想这一切都错了吗?谢谢。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。