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


PHP Security::randomBytes方法代碼示例

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


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

示例1: boundary

 /**
  * Get the boundary marker
  *
  * @return string
  */
 public function boundary()
 {
     if ($this->_boundary) {
         return $this->_boundary;
     }
     $this->_boundary = md5(Security::randomBytes(16));
     return $this->_boundary;
 }
開發者ID:tgr0ss,項目名稱:cakephp,代碼行數:13,代碼來源:FormData.php

示例2: setSecuritySalt

 /**
  * Set the security.salt value in the application's config file.
  *
  * @param string $dir The application's root directory.
  * @param \Composer\IO\IOInterface $io IO interface to write to console.
  * @return void
  */
 public static function setSecuritySalt($dir, $io)
 {
     $config = $dir . '/config/app.php';
     $content = file_get_contents($config);
     $newKey = hash('sha256', Security::randomBytes(64));
     $content = str_replace('__SALT__', $newKey, $content, $count);
     if ($count == 0) {
         $io->write('No Security.salt placeholder to replace.');
         return;
     }
     $result = file_put_contents($config, $content);
     if ($result) {
         $io->write('Updated Security.salt value in config/app.php');
         return;
     }
     $io->write('Unable to update Security.salt value.');
 }
開發者ID:scherersoftware,項目名稱:cakephp-app-template,代碼行數:24,代碼來源:Installer.php

示例3: _setCookie

 /**
  * Set the cookie in the response.
  *
  * Also sets the request->params['_csrfToken'] so the newly minted
  * token is available in the request data.
  *
  * @param \Cake\Network\Request $request The request object.
  * @param \Cake\Network\Response $response The response object.
  * @return void
  */
 protected function _setCookie(Request $request, Response $response)
 {
     $expiry = new Time($this->_config['expiry']);
     $value = hash('sha512', Security::randomBytes(16), false);
     $request->params['_csrfToken'] = $value;
     $response->cookie(['name' => $this->_config['cookieName'], 'value' => $value, 'expire' => $expiry->format('U'), 'path' => $request->webroot, 'secure' => $this->_config['secure'], 'httpOnly' => $this->_config['httpOnly']]);
 }
開發者ID:rlugojr,項目名稱:cakephp,代碼行數:17,代碼來源:CsrfComponent.php

示例4: _rsaSha1

 /**
  * Use RSA-SHA1 signing.
  *
  * This method is suitable for plain HTTP or HTTPS.
  *
  * @param \Cake\Http\Client\Request $request The request object.
  * @param array $credentials Authentication credentials.
  * @return string
  *
  * @throws \RuntimeException
  */
 protected function _rsaSha1($request, $credentials)
 {
     if (!function_exists('openssl_pkey_get_private')) {
         throw new RuntimeException('RSA-SHA1 signature method requires the OpenSSL extension.');
     }
     $nonce = isset($credentials['nonce']) ? $credentials['nonce'] : bin2hex(Security::randomBytes(16));
     $timestamp = isset($credentials['timestamp']) ? $credentials['timestamp'] : time();
     $values = ['oauth_version' => '1.0', 'oauth_nonce' => $nonce, 'oauth_timestamp' => $timestamp, 'oauth_signature_method' => 'RSA-SHA1', 'oauth_consumer_key' => $credentials['consumerKey']];
     if (isset($credentials['consumerSecret'])) {
         $values['oauth_consumer_secret'] = $credentials['consumerSecret'];
     }
     if (isset($credentials['token'])) {
         $values['oauth_token'] = $credentials['token'];
     }
     if (isset($credentials['tokenSecret'])) {
         $values['oauth_token_secret'] = $credentials['tokenSecret'];
     }
     $baseString = $this->baseString($request, $values);
     if (isset($credentials['realm'])) {
         $values['oauth_realm'] = $credentials['realm'];
     }
     if (is_resource($credentials['privateKey'])) {
         $resource = $credentials['privateKey'];
         $privateKey = stream_get_contents($resource);
         rewind($resource);
         $credentials['privateKey'] = $privateKey;
     }
     $credentials += ['privateKeyPassphrase' => null];
     if (is_resource($credentials['privateKeyPassphrase'])) {
         $resource = $credentials['privateKeyPassphrase'];
         $passphrase = stream_get_line($resource, 0, PHP_EOL);
         rewind($resource);
         $credentials['privateKeyPassphrase'] = $passphrase;
     }
     $privateKey = openssl_pkey_get_private($credentials['privateKey'], $credentials['privateKeyPassphrase']);
     $signature = '';
     openssl_sign($baseString, $signature, $privateKey);
     openssl_free_key($privateKey);
     $values['oauth_signature'] = base64_encode($signature);
     return $this->_buildAuth($values);
 }
開發者ID:nrother,項目名稱:cakephp,代碼行數:52,代碼來源:Oauth.php

示例5: _createBoundary

 /**
  * Create unique boundary identifier
  *
  * @return void
  */
 protected function _createBoundary()
 {
     if (!empty($this->_attachments) || $this->_emailFormat === 'both') {
         $this->_boundary = md5(Security::randomBytes(16));
     }
 }
開發者ID:nrother,項目名稱:cakephp,代碼行數:11,代碼來源:Email.php

示例6: testRandomBytes

 /**
  * Test the randomBytes method.
  *
  * @return void
  */
 public function testRandomBytes()
 {
     $value = Security::randomBytes(16);
     $this->assertSame(16, strlen($value));
     $value = Security::randomBytes(64);
     $this->assertSame(64, strlen($value));
     $this->assertRegExp('/[^0-9a-f]/', $value, 'should return a binary string');
 }
開發者ID:rashmi,項目名稱:newrepo,代碼行數:13,代碼來源:SecurityTest.php

示例7: generateVerificationContent

 public function generateVerificationContent()
 {
     $this->verification_content = hash('sha512', Security::randomBytes(16), false);
 }
開發者ID:benscobie,項目名稱:webaudit-website,代碼行數:4,代碼來源:Website.php

示例8: setSecuritySalt

 /**
  * Set the security.salt value in the application's config file.
  *
  * @param string $dir The application's root directory.
  * @param \Composer\IO\IOInterface $io IO interface to write to console.
  * @return void
  */
 public static function setSecuritySalt($dir, $io)
 {
     $newKey = hash('sha256', Security::randomBytes(64));
     static::setSecuritySaltInFile($dir, $io, $newKey, 'app.php');
     static::setSecuritySaltInFile($dir, $io, $newKey, '.env.default');
 }
開發者ID:josegonzalez,項目名稱:app,代碼行數:13,代碼來源:Installer.php


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