donglin5770
2017-04-29 12:13
浏览 118
已采纳

PHP:password_verify总是返回false

somehow I'm struggling with something that I expected to be straightforward. I created the following code just for testing purposes and I expected it to give the answer "valid password" in case the provided $login_password is "123456". But I always get "Invalid password."

$login_password = $_POST['login_password'];
$login_password_hash = password_hash($login_password, PASSWORD_DEFAULT);

$target_password = '123456';
$target_password_hash = password_hash($target_password, PASSWORD_DEFAULT);

if ( password_verify($login_password_hash, $target_password_hash) ) {
    echo "Valid password.";
    } 
else {
    echo "Invalid password.";
    }

I even get "Invalid password." when changing the password_verify to compare the same variable with itself:

password_verify($login_password_hash, $login_password_hash)

A little help is highly appreciated :)

图片转代码服务由CSDN问答提供 功能建议

某种程度上我正在努力做一些我期望直截了当的事情。 我创建了以下代码仅用于测试目的,我希望它提供答案“有效密码”,以防提供的$ login_password为“123456”。 但我总是得到“密码无效。”

  $ login_password = $ _ POST ['login_password']; 
 $ login_password_hash = password_hash($ login_password,PASSWORD_DEFAULT); 
 \  n $ target_password ='123456'; 
 $ target_password_hash = password_hash($ target_password,PASSWORD_DEFAULT); 
 
if(password_verify($ login_password_hash,$ target_password_hash)){
 echo“有效密码。”; 
} 
else  {
 echo“密码无效。”; 
} 
   
 
 

我甚至得到“密码无效”。 更改password_verify以将相同变量与其自身进行比较时:

  password_verify($ login_password_hash,$ login_password_hash)
   
 
 

非常感谢一点帮助:)

  • 写回答
  • 好问题 提建议
  • 追加酬金
  • 关注问题
  • 收藏
  • 邀请回答

2条回答 默认 最新

  • dongyuhui0418 2017-04-29 12:16
    已采纳

    You need to pass simple text password without hash as first param

    if ( password_verify($login_password , $target_password_hash) ) {
        echo "Valid password.";
        } 
    else {
        echo "Invalid password.";
        }
    
    评论
    解决 无用
    打赏 举报
查看更多回答(1条)

相关推荐 更多相似问题