當前位置: 首頁>>代碼示例>>PHP>>正文


PHP PasswordHash::slow_equals方法代碼示例

本文整理匯總了PHP中PasswordHash::slow_equals方法的典型用法代碼示例。如果您正苦於以下問題:PHP PasswordHash::slow_equals方法的具體用法?PHP PasswordHash::slow_equals怎麽用?PHP PasswordHash::slow_equals使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在PasswordHash的用法示例。


在下文中一共展示了PasswordHash::slow_equals方法的3個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。

示例1: validate_password

 public function validate_password($password, $correct_hash)
 {
     $params = explode(":", $correct_hash);
     if (count($params) < HASH_SECTIONS) {
         return false;
     }
     $pbkdf2 = base64_decode($params[HASH_PBKDF2_INDEX]);
     return PasswordHash::slow_equals($pbkdf2, PasswordHash::pbkdf2($params[HASH_ALGORITHM_INDEX], $password, $params[HASH_SALT_INDEX], (int) $params[HASH_ITERATION_INDEX], strlen($pbkdf2), true));
 }
開發者ID:croger46,項目名稱:oceanicdestiny,代碼行數:9,代碼來源:passwordHash.php

示例2: die

<?php

require_once 'db.php';
require_once 'PasswordHashClass.php';
# Make sure params are in place or die!
if (!isset($_GET['user']) || !isset($_GET['key'])) {
    die("Missing some parameters here");
}
$db = new PDO('mysql:host=' . DB_HOST . ';dbname=' . DB_NAME . ';charset=utf8', DB_USER, DB_PASS);
# Retrieve user data
$userCheck = $db->prepare("SELECT * FROM ovr_lists_login WHERE user_id = :id");
$userCheck->bindParam(':id', $_GET['user'], PDO::PARAM_INT);
$userCheck->execute();
if ($userCheck->rowCount() == 1) {
    $user = $userCheck->fetch(PDO::FETCH_ASSOC);
    $activation_hash_string = $user['user_id'] . $user['user_name'] . $user['user_email'] . $user['user_password_hash'];
    $generatedActivation = urlencode(hash_hmac('sha256', $activation_hash_string, $user['user_password_hash']));
    if (PasswordHash::slow_equals($generatedActivation, $_GET['key']) == 1) {
        $activateUser = $db->prepare("UPDATE ovr_lists_login SET activated = '1' WHERE user_id = :id");
        $activateUser->bindParam(':id', $_GET['user'], PDO::PARAM_INT);
        if ($activateUser->execute()) {
            echo "<h1>Activation successful</h1>";
        } else {
            echo "<h1 style='color:red'>Activation failed</h1>";
        }
    }
}
開發者ID:NerdyDillinger,項目名稱:ovrride,代碼行數:27,代碼來源:activate.php

示例3: PDO

require_once 'PasswordHashClass.php';
require_once 'db.php';
require_once 'Mandrill.php';
$db = new PDO('mysql:host=' . DB_HOST . ';dbname=' . DB_NAME . ';charset=utf8', DB_USER, DB_PASS);
if (isset($_POST['key']) && isset($_POST['user_id'])) {
    $hashCheck = $db->prepare("SELECT * FROM ovr_lists_login WHERE user_id = :id");
    $hashCheck->bindParam("id", $_POST['user_id'], PDO::PARAM_STR);
    $hashCheck->execute();
    if ($hashCheck->rowCount() !== 1) {
        echo "Something went wrong, please try again.";
    } else {
        $user = $hashCheck->fetch(PDO::FETCH_ASSOC);
        $hash_string = $user['user_id'] . $user['user_name'] . $user['user_email'] . $user['user_password_hash'];
        $reset_hash = urlencode(hash_hmac('sha256', $hash_string, $user['user_password_hash']));
        if (PasswordHash::slow_equals($_POST['key'], $reset_hash) == 1) {
            $hashed_password = PasswordHash::create_hash($_POST['user_password']);
            $passwordReset = $db->prepare("UPDATE ovr_lists_login SET user_password_hash = :password_hash, activated = '1' WHERE user_id = :id");
            if ($passwordReset->execute(array("password_hash" => $hashed_password, "id" => $_POST['user_id']))) {
                echo "Password has been reset go to <a href='https://{$_SERVER['SERVER_NAME']}/login/login.php'>https://{$_SERVER['SERVER_NAME']}/login/login.php</a> to login";
            } else {
                echo "Password failed to update.";
            }
        }
    }
} else {
    if (isset($_POST['Reset']) && $_POST['user_name'] && isset($_POST['user_email'])) {
        $userCheck = $db->prepare("SELECT * FROM ovr_lists_login WHERE user_name = :user AND user_email = :email");
        $userCheck->bindParam("user", $_POST['user_name'], PDO::PARAM_STR);
        $userCheck->bindParam("email", $_POST['user_email'], PDO::PARAM_STR);
        $userCheck->execute();
開發者ID:NerdyDillinger,項目名稱:ovrride,代碼行數:30,代碼來源:reset.php


注:本文中的PasswordHash::slow_equals方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。