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


PHP Password::randomBase64String方法代碼示例

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


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

示例1: getTokenValue

 /**
  * Get a CSRF Token value as stored in the session, or create one if it doesn't yet exist
  *
  * @param int|string|null $id Optional unique ID for this token
  * @return string
  *
  */
 public function getTokenValue($id = '')
 {
     $tokenName = $this->getTokenName($id);
     $tokenValue = $this->session->get($this, $tokenName);
     if (empty($tokenValue)) {
         // $tokenValue = md5($this->page->path() . mt_rand() . microtime()) . md5($this->page->name . $this->config->userAuthSalt . mt_rand());
         $pass = new Password();
         $tokenValue = $pass->randomBase64String(32);
         $this->session->set($this, $tokenName, $tokenValue);
     }
     return $tokenValue;
 }
開發者ID:avatar382,項目名稱:fablab_site,代碼行數:19,代碼來源:SessionCSRF.php

示例2: ___login

 /**
  * Login a user with the given name and password
  *
  * Also sets them to the current user
  *
  * @param string $name
  * @param string $pass Raw, non-hashed password
  * @return User Return the $user if the login was successful or null if not. 
  *
  */
 public function ___login($name, $pass)
 {
     $name = $this->wire('sanitizer')->pageName($name);
     if (!$this->allowLogin($name)) {
         $this->loginFailure($name, "User is not allowed to login");
         return null;
     }
     $user = strlen($name) ? $this->wire('users')->get("name={$name}") : null;
     if ($user && $user->id && $user->id != $this->wire('config')->guestUserPageID && $this->authenticate($user, $pass)) {
         $this->trackChange('login', $this->wire('user'), $user);
         session_regenerate_id(true);
         $this->set('_user', 'id', $user->id);
         $this->set('_user', 'ts', time());
         if ($this->config->sessionChallenge) {
             // create new challenge
             $pass = new Password();
             $challenge = $pass->randomBase64String(32);
             $this->set('_user', 'challenge', $challenge);
             // set challenge cookie to last 30 days (should be longer than any session would feasibly last)
             setcookie(session_name() . '_challenge', $challenge, time() + 60 * 60 * 24 * 30, '/', null, false, true);
         }
         if ($this->config->sessionFingerprint) {
             // remember a fingerprint that tracks the user's IP and user agent
             $this->set('_user', 'fingerprint', $this->getFingerprint());
         }
         $this->setFuel('user', $user);
         $this->get('CSRF')->resetAll();
         $this->loginSuccess($user);
         return $user;
     } else {
         if (!$user || !$user->id) {
             $reason = "Unknown user: {$name}";
         } else {
             if ($user->id == $this->wire('config')->guestUserPageID) {
                 $reason = "Guest user may not login";
             } else {
                 $reason = "Invalid password";
             }
         }
         $this->loginFailure($name, $reason);
     }
     return null;
 }
開發者ID:Rizsti,項目名稱:Processwire_Compatibility,代碼行數:53,代碼來源:Session.php

示例3: ___login

 /**
  * Login a user with the given name and password
  *
  * Also sets them to the current user
  *
  * @param string $name
  * @param string $pass Raw, non-hashed password
  * @return User Return the $user if the login was successful or null if not. 
  *
  */
 public function ___login($name, $pass)
 {
     if (!$this->allowLogin($name)) {
         return null;
     }
     $name = $this->wire('sanitizer')->username($name);
     $user = $this->wire('users')->get("name={$name}");
     if ($user->id && $this->authenticate($user, $pass)) {
         $this->trackChange('login', $this->wire('user'), $user);
         session_regenerate_id(true);
         $this->set('_user', 'id', $user->id);
         $this->set('_user', 'ts', time());
         if ($this->config->sessionChallenge) {
             // create new challenge
             $pass = new Password();
             $challenge = $pass->randomBase64String(32);
             $this->set('_user', 'challenge', $challenge);
             // set challenge cookie to last 30 days (should be longer than any session would feasibly last)
             setcookie(session_name() . '_challenge', $challenge, time() + 60 * 60 * 24 * 30, '/', null, false, true);
         }
         if ($this->config->sessionFingerprint) {
             // remember a fingerprint that tracks the user's IP and user agent
             $this->set('_user', 'fingerprint', md5($this->getIP(true) . $_SERVER['HTTP_USER_AGENT']));
         }
         $this->setFuel('user', $user);
         $this->get('CSRF')->resetAll();
         $this->loginSuccess($user);
         return $user;
     }
     return null;
 }
開發者ID:avatar382,項目名稱:fablab_site,代碼行數:41,代碼來源:Session.php


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