【发布时间】:2013-06-24 06:13:15
【问题描述】:
我的数据库存储 bcrypt 密码,这意味着盐应该存储在密码字段中。我不想在不需要的时候创建一个单独的字段来单独存储盐。但是,当我想将用户发送给我的密码与存储在数据库中的密码进行比较时,我需要使用相同的盐对传入的密码进行哈希处理。问题:存储的哈希的哪一部分是盐?我想我可以使用简单的 substr() 返回盐。
// password stored in database.
$user->password_hash = password_hash($password, PASSWORD_BCRYPT, array('cost' => 13));
// password from form being compared to form password
$form_password_hash = password_hash($data['form-password'], PASSWORD_BCRYPT, array('cost' => 13));
if($user->getPasswordHash() == $form_password_hash)
{
$user->setPassword($data['new-password']);
return new Response("Your password has been changed");
}
【问题讨论】:
-
否; bcrypt 为你做这件事。
-
我使用的每个 bcrypt 库都只处理整个字符串,您不需要单独传递盐。确定这是一种选择吗?
-
当您说“bcrypt 正在生成新盐”时,我听到“我做错了”。发布您的代码。
-
看看这个答案,根据你运行的版本,它有几种在 php 中使用 bcrypt 的方法:stackoverflow.com/a/6337021/1248861
-
@Mr.Student
password_verify为你做这件事。它不会生成新的盐,它使用您传入的哈希中包含的盐。
标签: php symfony hash cryptography bcrypt