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


PHP Crypt_Base::setKey方法代碼示例

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


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

示例1: setKey

 /**
  * Sets the key.
  *
  * Keys can be of any length.  Rijndael, itself, requires the use of a key that's between 128-bits and 256-bits long and
  * whose length is a multiple of 32.  If the key is less than 256-bits and the key length isn't set, we round the length
  * up to the closest valid key length, padding $key with null bytes.  If the key is more than 256-bits, we trim the
  * excess bits.
  *
  * If the key is not explicitly set, it'll be assumed to be all null bytes.
  *
  * Note: 160/224-bit keys must explicitly set by setKeyLength(), otherwise they will be round/pad up to 192/256 bits.
  *
  * @see Crypt_Base:setKey()
  * @see setKeyLength()
  * @access public
  * @param String $key
  */
 function setKey($key)
 {
     parent::setKey($key);
     if (!$this->explicit_key_length) {
         $length = strlen($key);
         switch (true) {
             case $length <= 16:
                 $this->key_size = 16;
                 break;
             case $length <= 24:
                 $this->key_size = 24;
                 break;
             default:
                 $this->key_size = 32;
         }
         $this->_setupEngine();
     }
 }
開發者ID:404rq,項目名稱:bgpanel,代碼行數:35,代碼來源:Rijndael.php

示例2: setKey

 /**
  * Sets the key.
  *
  * Keys can be of any length.  Blowfish, itself, requires the use of a key between 32 and max. 448-bits long.
  * If the key is less than 32-bits we NOT fill the key to 32bit but let the key as it is to be compatible
  * with mcrypt because mcrypt act this way with blowfish key's < 32 bits.
  *
  * If the key is more than 448-bits, we trim the excess bits.
  *
  * If the key is not explicitly set, or empty, it'll be assumed a 128 bits key to be all null bytes.
  *
  * @access public
  * @see Crypt_Base::setKey()
  * @param String $key
  */
 function setKey($key)
 {
     $keylength = strlen($key);
     if (!$keylength) {
         $key = "";
     } elseif ($keylength > 56) {
         $key = substr($key, 0, 56);
     }
     parent::setKey($key);
 }
開發者ID:nobitagamer,項目名稱:DAws,代碼行數:25,代碼來源:Blowfish.php

示例3: setKey

 /**
  * Sets the key.
  *
  * Keys can be of any length. RC2, itself, uses 1 to 1024 bit keys (eg.
  * strlen($key) <= 128), however, we only use the first 128 bytes if $key
  * has more then 128 bytes in it, and set $key to a single null byte if
  * it is empty.
  *
  * If the key is not explicitly set, it'll be assumed to be a single
  * null byte.
  *
  * @see Crypt_Base::setKey()
  * @access public
  * @param String $key
  * @param Integer $t1 optional          Effective key length in bits.
  */
 function setKey($key, $t1 = 0)
 {
     if ($t1 <= 0) {
         $t1 = $this->default_key_length;
     } else {
         if ($t1 > 1024) {
             $t1 = 1024;
         }
     }
     // Key byte count should be 1..128.
     $key = strlen($key) ? substr($key, 0, 128) : "";
     $t = strlen($key);
     // The mcrypt RC2 implementation only supports effective key length
     // of 1024 bits. It is however possible to handle effective key
     // lengths in range 1..1024 by expanding the key and applying
     // inverse pitable mapping to the first byte before submitting it
     // to mcrypt.
     // Key expansion.
     $l = array_values(unpack('C*', $key));
     $t8 = $t1 + 7 >> 3;
     $tm = 0xff >> 8 * $t8 - $t1;
     // Expand key.
     $pitable = $this->pitable;
     for ($i = $t; $i < 128; $i++) {
         $l[$i] = $pitable[$l[$i - 1] + $l[$i - $t]];
     }
     $i = 128 - $t8;
     $l[$i] = $pitable[$l[$i] & $tm];
     while ($i--) {
         $l[$i] = $pitable[$l[$i + 1] ^ $l[$i + $t8]];
     }
     // Prepare the key for mcrypt.
     $l[0] = $this->invpitable[$l[0]];
     array_unshift($l, 'C*');
     parent::setKey(call_user_func_array('pack', $l));
 }
開發者ID:tamboer,項目名稱:LaravelOctober,代碼行數:52,代碼來源:RC2.php

示例4: setKey

 /**
  * Sets the key.
  *
  * Keys can be of any length. Twofish, itself, requires the use of a key that's 128, 192 or 256-bits long.
  * If the key is less than 256-bits we round the length up to the closest valid key length,
  * padding $key with null bytes. If the key is more than 256-bits, we trim the excess bits.
  *
  * If the key is not explicitly set, it'll be assumed a 128 bits key to be all null bytes.
  *
  * @access public
  * @see Crypt_Base::setKey()
  * @param String $key
  */
 function setKey($key)
 {
     $keylength = strlen($key);
     switch (true) {
         case $keylength <= 16:
             $key = str_pad($key, 16, "");
             break;
         case $keylength <= 24:
             $key = str_pad($key, 24, "");
             break;
         case $keylength < 32:
             $key = str_pad($key, 32, "");
             break;
         case $keylength > 32:
             $key = substr($key, 0, 32);
     }
     parent::setKey($key);
 }
開發者ID:carlosmirandadiaz,項目名稱:LectoGeeks,代碼行數:31,代碼來源:Twofish.php

示例5: setKey

 /**
  * Sets the key.
  *
  * Keys can be between 1 and 256 bytes long.  If they are longer then 256 bytes, the first 256 bytes will
  * be used.  If no key is explicitly set, it'll be assumed to be a single null byte.
  *
  * @access public
  * @see    Crypt_Base::setKey()
  *
  * @param String $key
  */
 function setKey($key)
 {
     parent::setKey(substr($key, 0, 256));
 }
開發者ID:TheTypoMaster,項目名稱:SPHERE-Framework,代碼行數:15,代碼來源:RC4.php

示例6: setKey

 /**
  * Sets the key.
  *
  * Keys can be of any length.  DES, itself, uses 64-bit keys (eg. strlen($key) == 8), however, we
  * only use the first eight, if $key has more then eight characters in it, and pad $key with the
  * null byte if it is less then eight characters long.
  *
  * DES also requires that every eighth bit be a parity bit, however, we'll ignore that.
  *
  * If the key is not explicitly set, it'll be assumed to be all zero's.
  *
  * @see Crypt_Base::setKey()
  * @access public
  * @param String $key
  */
 function setKey($key)
 {
     // We check/cut here only up to max length of the key.
     // Key padding to the proper length will be done in _setupKey()
     if (strlen($key) > $this->key_size_max) {
         $key = substr($key, 0, $this->key_size_max);
     }
     // Sets the key
     parent::setKey($key);
 }
開發者ID:sawh,項目名稱:ostepu-system,代碼行數:25,代碼來源:DES.php

示例7: setKey

 /**
  * Sets the key.
  *
  * Keys can be of any length.  Rijndael, itself, requires the use of a key that's between 128-bits and 256-bits long and
  * whose length is a multiple of 32.  If the key is less than 256-bits and the key length isn't set, we round the length
  * up to the closest valid key length, padding $key with null bytes.  If the key is more than 256-bits, we trim the
  * excess bits.
  *
  * If the key is not explicitly set, it'll be assumed to be all null bytes.
  *
  * Note: 160/224-bit keys must explicitly set by setKeyLength(), otherwise they will be round/pad up to 192/256 bits.
  *
  * @see Crypt_Base:setKey()
  * @see self::setKeyLength()
  * @access public
  * @param string $key
  */
 function setKey($key)
 {
     if (!$this->explicit_key_length) {
         $length = strlen($key);
         switch (true) {
             case $length <= 16:
                 $this->key_size = 16;
                 break;
             case $length <= 20:
                 $this->key_size = 20;
                 break;
             case $length <= 24:
                 $this->key_size = 24;
                 break;
             case $length <= 28:
                 $this->key_size = 28;
                 break;
             default:
                 $this->key_size = 32;
         }
     }
     parent::setKey($key);
 }
開發者ID:jesusmarket,項目名稱:jesusmarket,代碼行數:40,代碼來源:Rijndael.php


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