javascript - 在数据库中散列密码有什么意义?

标签 javascript security bcrypt

我注意到大多数 api 教程都说您应该在发送之前对密码进行加密。它还展示了如何解密它们。如果我能做到,他们就不能做到吗?

这是 medium 中的示例

UserSchema.pre('save', function (next) {
  var user = this;
  bcrypt.hash(user.password, 10, function (err, hash){
    if (err) {
      return next(err);
    }
    user.password = hash;
    next();
  })
});

他们说在这里散列它

bcrypt.compare(password, user.password, function (err, result) 

当用户尝试登录时,他们会对其进行取消哈希处理。如果他们可以如此轻松地解散它,攻击者也不能解散它,这让我感到困惑吗?有人可以向我解释一下吗?

最佳答案

需要注意的是,虽然我已经编写了用户帐户系统并使用了安全哈希函数,但我不是任何类型的“专家”,但对于那些提出这个问题想知道是否真的必须经历的人使用安全哈希进行密码存储的麻烦:是的,您确实这样做。

此外,如果您仍然不确定,并且您对这些哈希方法的工作原理以及它们如何支持安全模型的理解感到不太舒服,那么您应该对您的工作人员诚实地说明这一点因为正确实现担保是困难的,需要经验和知识渊博的同行的审查。

无论如何,正如评论中提到的,专为密码存储而设计的安全哈希(例如 bcryptscrypt)有一个 API 可以处理所有困惑的工作。我更熟悉 scrypt 但它们很相似。哈希密码看起来像一串随机字符,但字符串的开头是两个单独的部分,其中包含随机盐和哈希参数。

由于用于密码存储的安全哈希总是会将任意长度和组成的密码哈希为某个固定大小的哈希字符串,因此没有充分的理由将用户密码限制为任意长度(除了 1000 个字符之类的长度,只是为了避免DOS 攻击)。

关于javascript - 在数据库中散列密码有什么意义?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53210928/

相关文章:

javascript - 每次显示警报时都会增加 sessionStorage 值

javascript - 使用 "let"关键字的 block 作用域

php - 当使用 PHP 的 crypt() 函数创建 bcrypt 哈希时,我需要盐吗?

javascript - python bcrypt 和 node.js bcrypt

git - 在不打开管理用户的情况下设置 git SSH 服务器

java - 如何在 Coldfusion8 中使用 javaloader 设置 java 库?

javascript - 折叠/展开 Accordion 菜单

javascript - 使用 Angular 和分页从数组中获取下一组和上一组记录

php - PHP 密码的安全散列和盐

python - HeartBleed python 测试脚本