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


PHP Crypto::GenerateKey方法代碼示例

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


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

示例1: json_decode

if (isset($_POST['login'])) {
    $login = (array) json_decode(base64_decode($_POST['login']));
    if ($field = Submission::checkFields(array("username", "password"), $login)) {
        die(Submission::createResult(ucfirst($field) . " is missing or invalid"));
    }
    if (Settings::i()->captcha_private) {
        if (!isset($login['captcha_response'])) {
            die(Submission::createResult("Please validate the captcha"));
        }
        $reCaptcha = new ReCaptcha(Settings::i()->captcha_private);
        $resp = $reCaptcha->verifyResponse($_SERVER["REMOTE_ADDR"], $login['captcha_response']);
        if (!$resp->success) {
            die(Submission::createResult("Please validate the Captcha"));
        }
    }
    $key = Crypto::GenerateKey($login['username']);
    $find = DbManager::i()->select("sf_members", array("iv", "userid"), array("key" => base64_encode(base64_encode($key))));
    if ($find !== false) {
        if (!is_array($find)) {
            $iv = base64_decode(base64_decode($find->iv));
            $password = base64_encode(base64_encode(Crypto::EncryptString($key, $iv, $login['password'])));
            $find = DbManager::i()->select("sf_members", array("userid"), array("password" => $password));
            if ($find !== false && !is_array($find)) {
                echo Submission::createResult("login successful", true);
                $_SESSION['login'] = 1;
                $_SESSION['userid'] = $find->userid;
                $find = DbManager::i()->select("sf_carts", array("cart"), array("userid" => $find->userid));
                if ($find !== false && !is_array($find)) {
                    //cart already exists for user
                    if ($find->cart != "e30=" && strlen($find->cart) != 4) {
                        //not empty cart - overwrite with saved one from DB
開發者ID:sharedRoutine,項目名稱:ShopFix,代碼行數:31,代碼來源:login.php

示例2: die

         die(Submission::createResult("Passwords do not match"));
     }
 }
 if (!is_null(Settings::i()->captcha_private)) {
     if (!isset($registration['captcha_response'])) {
         die(Submission::createResult("Please validate the captcha"));
     }
     $reCaptcha = new ReCaptcha(Settings::i()->captcha_private);
     $resp = $reCaptcha->verifyResponse($_SERVER["REMOTE_ADDR"], $registration['captcha_response']);
     if (!$resp->success) {
         die(Submission::createResult("Please validate the Captcha"));
     }
 }
 $u = $registration['username'];
 $iv = Crypto::GenerateIV();
 $key = Crypto::GenerateKey($u);
 $username = base64_encode(base64_encode(Crypto::EncryptString($key, $iv, $u)));
 $find = DbManager::i()->select("sf_members", array("userid"), array("key" => base64_encode(base64_encode($key))));
 if ($find && count($find) > 0) {
     die(Submission::createResult("Username is already taken"));
 }
 $pw = base64_encode(base64_encode(Crypto::EncryptString($key, $iv, $registration['password'])));
 $email = base64_encode(base64_encode(Crypto::EncryptString($key, $iv, $registration['email'])));
 $ip = base64_encode(base64_encode(Crypto::EncryptString($key, $iv, $_SERVER['REMOTE_ADDR'])));
 $key = base64_encode(base64_encode($key));
 $iv = base64_encode(base64_encode($iv));
 $reg_date = date("Y-m-d");
 $insert = DbManager::i()->insert("sf_members", array("username", "email", "password", "key", "iv", "register_date", "ip"), array($username, $email, $pw, $key, $iv, $reg_date, $ip));
 if ($insert) {
     Logger::i()->writeLog("Account created with username: {$u}");
     die(Submission::createResult("Your account has been created successfully", true));
開發者ID:sharedRoutine,項目名稱:ShopFix,代碼行數:31,代碼來源:register.php


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