0
|
sudoExclamationExclamation · 技术社区 · 9 月前 |
![]() |
1
5
现代密码哈希算法包含“成本参数”,这些参数以性能与安全性进行权衡——简单地说,你希望验证哈希值 太慢了 让攻击者尝试许多可能的密码,但是 足够快 合法用户不会认为你的应用程序坏了。 为了在提供正确密码时生成匹配的哈希,您需要知道用于生成存储哈希的确切参数。正如你所说,你 能够 对这些参数进行硬编码,但这意味着 你永远无法改变它们 -特别是,随着计算机速度的加快,你希望你的哈希值变慢。 因此,常见的做法是将使用的参数与每个哈希一起存储;那么,如果你把它们换成 新 哈希,你仍然可以 验证 旧哈希。一些库还允许您在用户登录时检查存储的哈希是否使用最新的参数值——只要您有正确的密码,就可以保存一个新的、更安全的哈希。 同样,哈希算法有时会被发现被破坏,或者只是变得太容易被攻击者暴力破解。在这一点上,你可能想从Argon2换成完全不同的东西。同样,您需要知道哪些存储的哈希值正在使用Argon2,哪些正在使用新算法,因此常见的做法是在哈希值的开头指明使用的算法。 对于Argon2,这些参数的格式实际上是已发布标准的一部分,因此 全部的 Argon2的实现将生成并期望这些精确的前缀。当你 能够 剥去它们,这样做真的没有什么好处,反而会损失很多。
至于实际参数是什么
意思是
,您可以在链接的Rust文档中,特别是在
the
|
![]() |
Legolas · 漫游用户配置文件密码文件位置 7 年前 |
|
user3607758 · 密码验证需要多长时间?[已关闭] 7 年前 |
![]() |
Schwaitz · 我可以用纯文本存储sha256散列密码吗? 9 年前 |
|
user1121477 · PHP hash_password函数 10 年前 |