gpt4 book ai didi

php - 为什么 password_verify 返回 false?

转载 作者:可可西里 更新时间:2023-11-01 06:53:16 24 4
gpt4 key购买 nike

我正在使用 password_verify 检查我的散列密码。我有 PHP 5.5:

   $this->db_connection = new mysqli(DB_HOST, DB_USER, DB_PASS, DB_NAME);


// if no connection errors (= working database connection)
if (!$this->db_connection->connect_errno) {

// escape the POST stuff
$user_name = $this->db_connection->real_escape_string($_POST['user_name']);

// database query, getting all the info of the selected user (allows login via email address in the
// username field)
$sql = "SELECT user_name, user_email, user_password_hash
FROM users
WHERE user_name = '" . $user_name . "' OR user_email = '" . $user_name . "';";
$result_of_login_check = $this->db_connection->query($sql);

// if this user exists
if ($result_of_login_check->num_rows == 1) {

// get result row (as an object)
$result_row = $result_of_login_check->fetch_object();

// using PHP 5.5's password_verify() function to check if the provided password fits
// the hash of that user's password


if (password_verify($_POST['user_password'], $result_row->user_password_hash)) {

// write user data into PHP SESSION (a file on your server)
$_SESSION['user_name'] = $result_row->user_name;
$_SESSION['user_email'] = $result_row->user_email;
$_SESSION['user_login_status'] = 1;

我在 password_verify 上得到了 false。我已经检查了帖子值和 mysql user_password_hash 返回值。

不知道为什么会返回false

有什么想法吗?

最佳答案

问题可能出在您的列长度上,从手册中可以看出:建议将结果存储在可以扩展到超过 60 个字符(255 个字符是一个不错的选择)的数据库列中。 link

关于php - 为什么 password_verify 返回 false?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21741424/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com