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


PHP Crypto::CreateNewRandomKey方法代碼示例

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


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

示例1: set_session

 /**
  * [set_session 設置session]
  * @param [type] $user[用戶信息]
  */
 public function set_session($user)
 {
     session_start();
     $_SESSION[$this->login_in_session_name] = $user;
     $key = Crypto::CreateNewRandomKey();
     $safe_session_id = base64_encode($key . Crypto::Encrypt(session_id(), $key));
     return $safe_session_id;
 }
開發者ID:897475686,項目名稱:bbm,代碼行數:12,代碼來源:auth_service.php

示例2: createDocument

 public function createDocument($title, $plainContent, User $creator, $passPhrase)
 {
     $key = \Crypto::CreateNewRandomKey();
     $encryptedKey = KeyGen::encrypt($key, $creator->getPublicKey());
     $document = new Document($creator, $encryptedKey);
     $this->documentRepository->persist($document->getShares()[0]);
     $this->updateDocument($document, $title, $plainContent, $creator, $passPhrase);
     return $document;
 }
開發者ID:trivago-tgoik,項目名稱:kis,代碼行數:9,代碼來源:DocumentService.php

示例3: TestEncryptDecrypt

 private static function TestEncryptDecrypt()
 {
     $key = Crypto::CreateNewRandomKey();
     $data = "EnCrYpT EvErYThInG";
     // Make sure encrypting then decrypting doesn't change the message.
     $ciphertext = Crypto::Encrypt($data, $key);
     try {
         $decrypted = Crypto::Decrypt($ciphertext, $key);
     } catch (InvalidCiphertextException $ex) {
         // It's important to catch this and change it into a
         // CryptoTestFailedException, otherwise a test failure could trick
         // the user into thinking it's just an invalid ciphertext!
         throw new CryptoTestFailedException();
     }
     if ($decrypted !== $data) {
         throw new CryptoTestFailedException();
     }
     // Modifying the ciphertext: Appending a string.
     try {
         Crypto::Decrypt($ciphertext . "a", $key);
         throw new CryptoTestFailedException();
     } catch (InvalidCiphertextException $e) {
         /* expected */
     }
     // Modifying the ciphertext: Changing an IV byte.
     try {
         $ciphertext[0] = chr((ord($ciphertext[0]) + 1) % 256);
         Crypto::Decrypt($ciphertext, $key);
         throw new CryptoTestFailedException();
     } catch (InvalidCiphertextException $e) {
         /* expected */
     }
     // Decrypting with the wrong key.
     $key = Crypto::CreateNewRandomKey();
     $data = "abcdef";
     $ciphertext = Crypto::Encrypt($data, $key);
     $wrong_key = Crypto::CreateNewRandomKey();
     try {
         Crypto::Decrypt($ciphertext, $wrong_key);
         throw new CryptoTestFailedException();
     } catch (InvalidCiphertextException $e) {
         /* expected */
     }
     // Ciphertext too small (shorter than HMAC).
     $key = Crypto::CreateNewRandomKey();
     $ciphertext = str_repeat("A", self::MAC_BYTE_SIZE - 1);
     try {
         Crypto::Decrypt($ciphertext, $key);
         throw new CryptoTestFailedException();
     } catch (InvalidCiphertextException $e) {
         /* expected */
     }
 }
開發者ID:deenison,項目名稱:joomla-cms,代碼行數:53,代碼來源:Crypto.php

示例4: catch

<?php

require_once 'Crypto.php';
try {
    $key = Crypto::CreateNewRandomKey();
    // WARNING: Do NOT encode $key with bin2hex() or base64_encode(),
    // they may leak the key to the attacker through side channels.
} catch (CryptoTestFailedException $ex) {
    die('Cannot safely create a key');
} catch (CannotPerformOperationException $ex) {
    die('Cannot safely create a key');
}
$message = "ATTACK AT DAWN";
try {
    $ciphertext = Crypto::Encrypt($message, $key);
} catch (CryptoTestFailedException $ex) {
    die('Cannot safely perform encryption');
} catch (CannotPerformOperationException $ex) {
    die('Cannot safely perform decryption');
}
try {
    $decrypted = Crypto::Decrypt($ciphertext, $key);
} catch (InvalidCiphertextException $ex) {
    // VERY IMPORTANT
    // Either:
    //   1. The ciphertext was modified by the attacker,
    //   2. The key is wrong, or
    //   3. $ciphertext is not a valid ciphertext or was corrupted.
    // Assume the worst.
    die('DANGER! DANGER! The ciphertext has been tampered with!');
} catch (CryptoTestFailedException $ex) {
開發者ID:ZerGabriel,項目名稱:friendica,代碼行數:31,代碼來源:example.php

示例5: getEncryptionKey

 /**
  * Retrieves the encryption key from cache, or generations a new one in the instance one does not exists
  * @return string
  */
 public static function getEncryptionKey()
 {
     $key = self::getConfig('encryptionKey', NULL, 'settings_', true);
     if ($key == NULL || $key == "") {
         try {
             $key = Crypto::CreateNewRandomKey();
         } catch (CryptoTestFailedException $ex) {
             throw new CException('Encryption key generation failed');
         } catch (CannotPerformOperationException $ex) {
             throw new CException('Encryption key generation failed');
         }
         $config = new Configuration();
         $config->attributes = array('key' => 'encryptionkey', 'value' => bin2hex($key));
         if (!$config->save()) {
             throw new CException('Encryption key generation failed');
         }
     }
     return hex2bin(self::getConfig('encryptionKey', NULL, 'settings_', true));
 }
開發者ID:charlesportwoodii,項目名稱:cii,代碼行數:23,代碼來源:Cii.php

示例6: generateKey

 /**
  * Generate new random encryption key (binary format).
  *
  * @return string
  */
 public function generateKey()
 {
     return \Crypto::CreateNewRandomKey();
 }
開發者ID:spiral,項目名稱:components,代碼行數:9,代碼來源:EncrypterManager.php

示例7: generateKey

 /**
  * Method to generate a new encryption key object.
  *
  * @param   array  $options  Key generation options.
  *
  * @return  JCryptKey
  *
  * @since   3.5
  * @throws  RuntimeException
  */
 public function generateKey(array $options = array())
 {
     // Create the new encryption key object.
     $key = new JCryptKey('crypto');
     // Generate the encryption key.
     try {
         $key->public = Crypto::CreateNewRandomKey();
     } catch (CryptoTestFailedException $ex) {
         throw new RuntimeException('Cannot safely create a key', $ex->getCode(), $ex);
     } catch (CannotPerformOperationException $ex) {
         throw new RuntimeException('Cannot safely create a key', $ex->getCode(), $ex);
     }
     // Explicitly flag the private as unused in this cipher.
     $key->private = 'unused';
     return $key;
 }
開發者ID:SysBind,項目名稱:joomla-cms,代碼行數:26,代碼來源:crypto.php


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