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


PHP Random::bytes方法代碼示例

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


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

示例1: build

 /**
  * Internal function used to build the actual hash.
  *  
  * @param string       $input    Data to hash
  * @param string       $password Password to use in HMAC call
  * @param integer      $cost     Number of iterations to use
  * @param string|null  $salt     Initialization vector to use in HMAC calls
  * @return string
  */
 private static function build($input, $password, $cost, $salt = null)
 {
     // Generate salt if needed
     $salt = $salt === null ? Random::bytes(16) : $salt;
     // Verify and normalize cost value
     $cost = self::cost($cost);
     // Create key to use for hmac operations
     $key = \hash_hmac(self::ALGO, $salt, $password, true);
     // Perform hash iterations. Get a 32 byte output value
     $hash = self::ihmac($input, $key, $cost, self::ALGO);
     // Return the salt + cost blob + hmac
     return $salt . self::costHash($cost, $salt, $password) . $hash;
 }
開發者ID:dopecode,項目名稱:dcrypt,代碼行數:22,代碼來源:Hash.php

示例2: equal

 /**
  * Compares two strings in constant time. Strings are hashed before 
  * comparison so information is not leaked when strings are not of
  * equal length.
  *
  * @param string $known       The string of known length to compare against
  * @param string $given       The string that the user can control
  *
  * @return bool
  */
 public static function equal($known, $given)
 {
     // We hash the 2 inputs at this point because hash_equals is still
     // vulnerable to timing attacks when the inputs have different sizes.
     // Inputs are also cast to string like in symfony stringutils.
     $nonce = Random::bytes(32);
     $known = \hash_hmac('sha256', (string) $known, $nonce, true);
     $given = \hash_hmac('sha256', (string) $given, $nonce, true);
     if (\function_exists('hash_equals')) {
         return \hash_equals($known, $given);
         // @codeCoverageIgnore
     }
     return self::strcmp($known, $given);
 }
開發者ID:dopecode,項目名稱:dcrypt,代碼行數:24,代碼來源:Str.php

示例3: encrypt

 /**
  * Encrypt plaintext
  * 
  * @param string $plaintext Plaintext string to encrypt
  * @param string $password  Key used to encrypt data
  * @param int    $cost      Number of HMAC iterations to perform on key
  * @param string $cipher    Mcrypt cipher
  * @param string $mode      Mcrypt mode
  * @param string $algo      Hashing algorithm to use for internal operations
  * 
  * @return string 
  */
 public static function encrypt($plaintext, $password, $cost = 0, $cipher = MCRYPT_RIJNDAEL_128, $mode = MCRYPT_MODE_CBC, $algo = 'sha256')
 {
     // Pad the input string to a multiple of block size
     $padded = Pkcs7::pad($plaintext, \mcrypt_get_block_size($cipher, $mode));
     // Generate IV of appropriate size
     $iv = Random::bytes(\mcrypt_get_iv_size($cipher, $mode));
     // Derive key from password
     $key = self::key($password, $iv, $cost, $cipher, $mode, $algo);
     // Encrypt the plaintext
     $message = \mcrypt_encrypt($cipher, $key, $padded, $mode, $iv);
     // Create the cypher text prefix (iv + checksum)
     $prefix = $iv . self::checksum($message, $iv, $key, $cipher, $mode, $algo);
     // Return prefix + cyphertext
     return $prefix . $message;
 }
開發者ID:dopecode,項目名稱:dcrypt,代碼行數:27,代碼來源:Mcrypt.php

示例4: testLength

 public function testLength()
 {
     $this->assertSame(32, strlen(Random::bytes(32)));
 }
開發者ID:J0s3f,項目名稱:simpleid,代碼行數:4,代碼來源:RandomTest.php

示例5: bin2hex

                    <div class="col-sm-12">

                        <h4>PHP Implementation Tests</h4>
<?php 
$my_random_boolean = Random::boolean() ? 1 : 0;
$result_true = 0;
$result_false = 0;
for ($i = 1; $i <= 100; $i++) {
    if (Random::boolean()) {
        $result_true++;
    } else {
        $result_false++;
    }
}
$my_random_bytes = bin2hex(Random::bytes(10));
$my_random_float = Random::float();
$my_random_integer = Random::int(0, PHP_INT_MAX);
$my_random_integer_2 = Random::int(1, 100);
$my_random_string = Random::string(20);
$my_random_string_2 = Random::string(20, "!\"#\$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\\]^_`abcdefghijklmnopqrstuvwxyz{|}~");
?>
                        <table class="table table-bordered" style="table-layout: fixed; word-wrap: break-word;">
                            <tbody>
                                <tr>
                                    <td style="width: 50%;"><pre><code>$my_random_boolean = Random::boolean() ? 1 : 0;</code></pre></td>
                                    <td><?php 
echo $my_random_boolean;
?>
</td>
                                </tr>
開發者ID:Qnatz,項目名稱:starter-public-edition-4,代碼行數:30,代碼來源:random.php

示例6: testLength

 public function testLength()
 {
     $this->assertEquals(10, strlen(Random::bytes(10)));
 }
開發者ID:jivoo,項目名稱:core,代碼行數:4,代碼來源:RandomTest.php

示例7: encrypt

 /**
  * Encrypt plaintext
  * 
  * @param string $plaintext Plaintext string to encrypt.
  * @param string $password  Password used to encrypt data.
  * @param int    $cost      Number of HMAC iterations to perform on key
  * 
  * @return string 
  */
 public static function encrypt($plaintext, $password, $cost = 0)
 {
     // Generate IV of appropriate size.
     $iv = Random::bytes(self::IVSIZE);
     // Derive key from password
     $key = self::key($password, $iv, $cost, self::RIJNDA, self::mode());
     // Encrypt the plaintext
     $message = \openssl_encrypt($plaintext, static::CIPHER, $key, 1, $iv);
     // Create the cypher text prefix (iv + checksum)
     $prefix = $iv . self::checksum($message, $iv, $key, self::RIJNDA, self::mode());
     // Return prefix + cyphertext
     return $prefix . $message;
 }
開發者ID:dopecode,項目名稱:dcrypt,代碼行數:22,代碼來源:Aes.php


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