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


PHP SecurityUtil::hashPassword方法代碼示例

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


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

示例1: authenticate

 private function authenticate($column, $loginstr, $password)
 {
     $fromTable = $this->_websoccer->getConfig('db_prefix') . '_user';
     // get user data
     $columns = 'id, passwort, passwort_neu, passwort_salt';
     $wherePart = $column . ' = \'%s\' AND status = 1';
     $parameter = $loginstr;
     $result = $this->_db->querySelect($columns, $fromTable, $wherePart, $parameter);
     $userdata = $result->fetch_array();
     $result->free();
     // user does not exist
     if (!$userdata['id']) {
         return FALSE;
     }
     // check password
     $inputPassword = SecurityUtil::hashPassword($password, $userdata['passwort_salt']);
     if ($inputPassword != $userdata['passwort'] && $inputPassword != $userdata['passwort_neu']) {
         return FALSE;
     }
     // update password after a generated one
     if ($userdata['passwort_neu'] == $inputPassword) {
         $columns = array('passwort' => $inputPassword, 'passwort_neu_angefordert' => 0, 'passwort_neu' => '');
         $whereCondition = 'id = %d';
         $parameter = $userdata['id'];
         $this->_db->queryUpdate($columns, $fromTable, $whereCondition, $parameter);
     }
     return $userdata['id'];
 }
開發者ID:astroChasqui,項目名稱:open-websoccer,代碼行數:28,代碼來源:DefaultUserLoginMethod.class.php

示例2: executeAction

 /**
  * (non-PHPdoc)
  * @see IActionController::executeAction()
  */
 public function executeAction($parameters)
 {
     $user = $this->_websoccer->getUser();
     $columns = array();
     // save new password
     if ($parameters["newpassword"] != null) {
         // always create new salt (in order to invalid old cookies)
         $salt = SecurityUtil::generatePasswordSalt();
         $hashedPassword = SecurityUtil::hashPassword($parameters["newpassword"], $salt);
         $columns["passwort_salt"] = $salt;
         $columns["passwort"] = $hashedPassword;
     }
     // handle new e-mail
     if ($parameters["newemail"] != null) {
         $activationKey = SecurityUtil::generatePassword();
         $columns["schluessel"] = $activationKey;
         $columns["status"] = 2;
         $columns["email"] = $parameters["newemail"];
         $user->email = $parameters["newemail"];
         // send e-mail
         $querystr = "key=" . $columns["schluessel"] . "&userid=" . $user->id;
         $tplparameters["activationlink"] = $this->_websoccer->getInternalActionUrl("activate", $querystr, "activate-user", TRUE);
         // send e-mail
         EmailHelper::sendSystemEmailFromTemplate($this->_websoccer, $this->_i18n, $user->email, $this->_i18n->getMessage("activation_changedemail_subject"), "changed_email_activation", $tplparameters);
         $this->_websoccer->addFrontMessage(new FrontMessage(MESSAGE_TYPE_WARNING, $this->_i18n->getMessage("profile_changedemail_message_title"), $this->_i18n->getMessage("profile_changedemail_message_content")));
     }
     $columns["name"] = $parameters["realname"];
     $columns["wohnort"] = $parameters["place"];
     $columns["land"] = $parameters["country"];
     $columns["beruf"] = $parameters["occupation"];
     $columns["interessen"] = $parameters["interests"];
     $columns["lieblingsverein"] = $parameters["favorite_club"];
     $columns["homepage"] = $parameters["homepage"];
     $columns["c_hideinonlinelist"] = $parameters["c_hideinonlinelist"];
     if ($parameters["birthday"]) {
         $dateObj = DateTime::createFromFormat($this->_websoccer->getConfig("date_format"), $parameters["birthday"]);
         $columns["geburtstag"] = $dateObj->format("Y-m-d");
     }
     // update record
     if (count($columns)) {
         $fromTable = $this->_websoccer->getConfig("db_prefix") . "_user";
         $whereCondition = "id = %d";
         $this->_db->queryUpdate($columns, $fromTable, $whereCondition, $user->id);
     }
     // success message
     $this->_websoccer->addFrontMessage(new FrontMessage(MESSAGE_TYPE_SUCCESS, $this->_i18n->getMessage("saved_message_title"), ""));
     return "profile";
 }
開發者ID:astroChasqui,項目名稱:open-websoccer,代碼行數:52,代碼來源:SaveProfileController.class.php

示例3: executeAction

 public function executeAction($parameters)
 {
     if (!$this->_websoccer->getConfig("login_allow_sendingpassword")) {
         throw new Exception("Action is disabled.");
     }
     // check captcha
     if ($this->_websoccer->getConfig("register_use_captcha") && strlen($this->_websoccer->getConfig("register_captcha_publickey")) && strlen($this->_websoccer->getConfig("register_captcha_privatekey"))) {
         include_once BASE_FOLDER . "/lib/recaptcha/recaptchalib.php";
         $captchaResponse = recaptcha_check_answer($this->_websoccer->getConfig("register_captcha_privatekey"), $_SERVER["REMOTE_ADDR"], $_POST["recaptcha_challenge_field"], $_POST["recaptcha_response_field"]);
         if (!$captchaResponse->is_valid) {
             throw new Exception($this->_i18n->getMessage("registration_invalidcaptcha"));
         }
     }
     $email = $parameters["useremail"];
     $fromTable = $this->_websoccer->getConfig("db_prefix") . "_user";
     // get user
     $columns = "id, passwort_salt, passwort_neu_angefordert";
     $wherePart = "UPPER(email) = '%s' AND status = 1";
     $result = $this->_db->querySelect($columns, $fromTable, $wherePart, strtoupper($email));
     $userdata = $result->fetch_array();
     $result->free();
     if (!isset($userdata["id"])) {
         sleep(5);
         throw new Exception($this->_i18n->getMessage("forgot-password_email-not-found"));
     }
     $now = $this->_websoccer->getNowAsTimestamp();
     $timeBoundary = $now - 24 * 3600;
     if ($userdata["passwort_neu_angefordert"] > $timeBoundary) {
         throw new Exception($this->_i18n->getMessage("forgot-password_already-sent"));
     }
     // create new password
     $salt = $userdata["passwort_salt"];
     if (!strlen($salt)) {
         $salt = SecurityUtil::generatePasswordSalt();
     }
     $password = SecurityUtil::generatePassword();
     $hashedPassword = SecurityUtil::hashPassword($password, $salt);
     // update user
     $columns = array("passwort_salt" => $salt, "passwort_neu_angefordert" => $now, "passwort_neu" => $hashedPassword);
     $whereCondition = "id = %d";
     $parameter = $userdata["id"];
     $this->_db->queryUpdate($columns, $fromTable, $whereCondition, $parameter);
     $this->_sendEmail($email, $password);
     $this->_websoccer->addFrontMessage(new FrontMessage(MESSAGE_TYPE_SUCCESS, $this->_i18n->getMessage("forgot-password_message_title"), $this->_i18n->getMessage("forgot-password_message_content")));
     return "login";
 }
開發者ID:astroChasqui,項目名稱:open-websoccer,代碼行數:46,代碼來源:SendPasswordController.class.php

示例4: toDbValue

 /**
  * @see IConverter::toDbValue()
  */
 public function toDbValue($value)
 {
     if (isset($_POST['id']) && $_POST['id']) {
         $db = DbConnection::getInstance();
         $columns = 'passwort, passwort_salt';
         $fromTable = $this->_websoccer->getConfig('db_prefix') . '_admin';
         $whereCondition = 'id = %d';
         $result = $db->querySelect($columns, $fromTable, $whereCondition, $_POST['id'], 1);
         $admin = $result->fetch_array();
         $result->free();
         if (strlen($value)) {
             $passwort = SecurityUtil::hashPassword($value, $admin['passwort_salt']);
         } else {
             $passwort = $admin['passwort'];
         }
     } else {
         $passwort = SecurityUtil::hashPassword($value, '');
     }
     return $passwort;
 }
開發者ID:astroChasqui,項目名稱:open-websoccer,代碼行數:23,代碼來源:AdminPasswordConverter.class.php

示例5: actionSaveUser

function actionSaveUser()
{
    global $errors;
    global $messages;
    $requiredFields = array("name", "password", "email");
    foreach ($requiredFields as $requiredField) {
        if (!isset($_POST[$requiredField]) || !strlen($_POST[$requiredField])) {
            $errors[] = $messages["requires_value"] . ": " . $messages["label_" . $requiredField];
        }
    }
    if (count($errors)) {
        return "printCreateUserForm";
    }
    $salt = SecurityUtil::generatePasswordSalt();
    $password = SecurityUtil::hashPassword($_POST["password"], $salt);
    $columns["name"] = $_POST["name"];
    $columns["passwort"] = $password;
    $columns["passwort_salt"] = $salt;
    $columns["email"] = $_POST["email"];
    $columns["r_admin"] = "1";
    include CONFIGFILE;
    $db = DbConnection::getInstance();
    $db->connect($conf["db_host"], $conf["db_user"], $conf["db_passwort"], $conf["db_name"]);
    $db->queryInsert($columns, $conf["db_prefix"] . "_admin");
    return "printFinalPage";
}
開發者ID:astroChasqui,項目名稱:open-websoccer,代碼行數:26,代碼來源:index.php

示例6: array

    if ($_POST['newpassword'] != $_POST['repeatpassword']) {
        $err[] = $i18n->getMessage("profile_validationerror_wrong_repeated_password");
    }
    if ($admin['r_demo']) {
        $err[] = $i18n->getMessage("validationerror_no_changes_as_demo");
    }
    if (isset($err)) {
        include "validationerror.inc.php";
    } else {
        echo "<h1>" . $mainTitle . " &raquo; " . $i18n->getMessage("subpage_save_title") . "</h1>";
        $fromTable = $conf['db_prefix'] . "_admin";
        $whereCondition = "id = %d";
        $parameter = $admin['id'];
        if ($_POST['newpassword']) {
            // create new salt
            if (!strlen($admin["passwort_salt"])) {
                $salt = SecurityUtil::generatePasswordSalt();
                $db->queryUpdate(array("passwort_salt" => $salt), $fromTable, $whereCondition, $parameter);
            } else {
                $salt = $admin["passwort_salt"];
            }
            $passwort = SecurityUtil::hashPassword(trim($_POST['newpassword']), $salt);
        } else {
            $passwort = $admin['passwort'];
        }
        $columns = array("passwort" => $passwort, "email" => $_POST['email'], "lang" => $_POST['language']);
        $db->queryUpdate($columns, $fromTable, $whereCondition, $parameter);
        echo createSuccessMessage($i18n->getMessage("alert_save_success"), "");
        echo "<p>&raquo; <a href=\"?site=" . $site . "\">" . $i18n->getMessage("back_label") . "</a></p>\n";
    }
}
開發者ID:astroChasqui,項目名稱:open-websoccer,代碼行數:31,代碼來源:profile.php

示例7: _createUser

 private function _createUser($parameters, $fromTable)
 {
     $dbcolumns = array();
     $dbcolumns["nick"] = $parameters["nick"];
     $dbcolumns["email"] = strtolower($parameters["email"]);
     $dbcolumns["passwort_salt"] = SecurityUtil::generatePasswordSalt();
     $dbcolumns["passwort"] = SecurityUtil::hashPassword($parameters["pswd"], $dbcolumns["passwort_salt"]);
     $dbcolumns["datum_anmeldung"] = $this->_websoccer->getNowAsTimestamp();
     $dbcolumns["schluessel"] = str_replace("&", "_", SecurityUtil::generatePassword());
     $dbcolumns["status"] = 2;
     $dbcolumns["lang"] = $this->_i18n->getCurrentLanguage();
     if ($this->_websoccer->getConfig("premium_initial_credit")) {
         $dbcolumns["premium_balance"] = $this->_websoccer->getConfig("premium_initial_credit");
     }
     $this->_db->queryInsert($dbcolumns, $fromTable);
     // get user id
     $columns = "id";
     $wherePart = "email = '%s'";
     $result = $this->_db->querySelect($columns, $fromTable, $wherePart, $dbcolumns["email"]);
     $newuser = $result->fetch_array();
     $result->free();
     $querystr = "key=" . $dbcolumns["schluessel"] . "&userid=" . $newuser["id"];
     $tplparameters["activationlink"] = $this->_websoccer->getInternalActionUrl("activate", $querystr, "activate-user", TRUE);
     // send e-mail
     EmailHelper::sendSystemEmailFromTemplate($this->_websoccer, $this->_i18n, $dbcolumns["email"], $this->_i18n->getMessage("activation_email_subject"), "useractivation", $tplparameters);
     // trigger plug-ins
     $event = new UserRegisteredEvent($this->_websoccer, $this->_db, $this->_i18n, $newuser["id"], $dbcolumns["nick"], $dbcolumns["email"]);
     PluginMediator::dispatchEvent($event);
 }
開發者ID:astroChasqui,項目名稱:open-websoccer,代碼行數:29,代碼來源:RegisterFormController.class.php

示例8: array

 $now = $website->getNowAsTimestamp();
 if (count($errors) == 0) {
     // correct Pwd?
     $columns = array('id', 'passwort_neu_angefordert', 'name', 'passwort_salt');
     $fromTable = $conf['db_prefix'] . '_admin';
     $whereCondition = 'email = \'%s\'';
     $parameters = $inputEmail;
     $result = $db->querySelect($columns, $fromTable, $whereCondition, $parameters);
     $admin = $result->fetch_array();
     if ($result->num_rows < 1) {
         $errors['inputEmail'] = $i18n->getMessage('sendpassword_admin_usernotfound');
     } elseif ($admin['passwort_neu_angefordert'] > $now - 120 * 60) {
         $errors['inputEmail'] = $i18n->getMessage('sendpassword_admin_alreadysent');
     } else {
         $newPassword = SecurityUtil::generatePassword();
         $hashedPw = SecurityUtil::hashPassword($newPassword, $admin['passwort_salt']);
         // store new PW
         $columns = array('passwort_neu' => $hashedPw, 'passwort_neu_angefordert' => $now);
         $fromTable = $conf['db_prefix'] . '_admin';
         $whereCondition = 'id = %d';
         $parameter = $admin['id'];
         $db->queryUpdate($columns, $fromTable, $whereCondition, $parameter);
         try {
             _sendEmail($inputEmail, $newPassword, $website, $i18n);
             header('location: login.php?newpwd=1');
             die;
         } catch (Exception $e) {
             $errors['inputEmail'] = $e->getMessage();
         }
     }
     $result->free();
開發者ID:astroChasqui,項目名稱:open-websoccer,代碼行數:31,代碼來源:forgot-password.php


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