2017-01-28 9 views
-2

У меня проблема с хешированием моего пароля (b-crypt). Я успешно выполнил эту функцию при регистрации пользователя: $hashed = password_hash($password, PASSWORD_DEFAULT);. Но я не знаю, как реализовать эту строку кода password_verify($password, $hashed_password) в моем коде.Password_verify, PDO

Это сегмент класса пользователя:

class User{ 
    private $db; 
    public function __construct() { 
     $this->db = new Database(); 
    } 

public function getLoginUser($email, $password){ 
     $sql = "SELECT * FROM tbl_user WHERE email = :email AND password = :password LIMIT 1"; 
     $query = $this->db->pdo->prepare($sql); 
     $query->bindValue(':email', $email); 
     $query->bindValue(':password', $password); 
     $query->execute(); 
     $result = $query->fetch(PDO::FETCH_OBJ); 
     return $result; 
    } 

    public function userLogin($data){ 
     $email = $data['email']; 
     $password = $data['password']; 
     $chk_email = $this->emailCheck($email); 

     if ($email == "" OR $password == "") { 
      $msg = "<div class='alert alert-danger'><strong>Error! </strong>Field must not be Empty!</div>"; 
      return $msg; 
     } 

     if (filter_var($email, FILTER_VALIDATE_EMAIL) === false) { 
      $msg = "<div class='alert alert-danger'><strong>Error! </strong>The E-mail address is not valid!</div>"; 
      return $msg; 
     } 

     if ($chk_email == false) { 
      $msg = "<div class='alert alert-danger'><strong>Error! </strong>The E-mail address Not Exist!</div>"; 
      return $msg; 
     } 

     if (password_verify('password', $hashed)) { 
      echo 'Password is valid!'; 
     } else { 
      echo 'Invalid password.'; 
     } 

     $result = $this->getLoginUser($email, $password); 

     if ($result) { 
      Session::init(); 
      Session::set("login", true); 
      Session::set("id", $result->id); 
      Session::set("name", $result->name); 
      Session::set("username", $result->username); 
      Session::set("loginmsg", "<div class='alert alert-success'><strong>Success! </strong>You are Logged In!</div>"); 
      header("Location: index.php"); 
     } else { 
      $msg = "<div class='alert alert-danger'><strong>Error! </strong>Data not found!</div>"; 
      return $msg; 
     } 
    } 

И это мой login.php с функцией Userlogin ($ _ POST); ,

<?php 
$user = new User(); 
if ($_SERVER['REQUEST_METHOD'] == 'POST' && isset($_POST['login'])) { 
    $usrLogin = $user->userLogin($_POST); 
} 

Может кто-нибудь ПОЖАЛУЙСТА ПОМОЧЬ мне с этой проблемой? Это будет полезно, если вы можете написать для меня этот код (сегмент).

Thank you and

Reegards!

+0

'$ hashed' определяется где и как? и какова длина столбца паролей? –

+0

Ваша проблема заключается в том, что оператор SQL проверяет пароль, но это невозможно, поскольку хеши паролей соленые и, следовательно, не доступны для поиска. Я попытался объяснить правильное обращение в другом [ответе] (http://stackoverflow.com/a/38422760/575765). – martinstoeckli

ответ

0

Вы используете password_hash хранить хэш пароля в базу данных

$hashed = password_hash($password, PASSWORD_DEFAULT); 

На странице авторизации вам необходимо восстановить старый хэш пароля из базы данных на основе пользователя электронной почты и проверить его против публикуемую пароля, как это

$password = $_POST['password']; 
if (password_verify($password, $hashed_password_from_database)) { 
    // login 
} else { 
    // error login failed 
}