为什么password_verify返回False?
当尝试使用PHP的password_verify函数验证密码时,如下所示,您可能会遇到false正面:
if (password_verify($_POST['user_password'], $result_row->user_password_hash)) { // ... }
原因:
问题可能源于数据库中密码哈希列的长度。根据 PHP 手册,建议将密码哈希存储在能够容纳至少 255 个字符的列中。这确保了与 bcrypt 算法的兼容性,该算法对长度敏感。
解决方案:
将数据库中密码哈希列的长度扩展至至少 255人物。为此,请相应地修改您的数据库架构,如下所示:
ALTER TABLE users MODIFY COLUMN user_password_hash VARCHAR(255);
这将允许password_verify 通过将密码与存储的哈希值进行比较来准确验证密码。
以上是为什么 PHP 中 `password_verify` 返回 False?的详细内容。更多信息请关注PHP中文网其他相关文章!