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


PHP Crypto::RuntimeTest方法代碼示例

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


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

示例1: setUpBeforeClass

 /**
  * This method is called before the first test of this test class is run.
  *
  * @return  void
  */
 public static function setUpBeforeClass()
 {
     // Only run the test if the environment supports it.
     try {
         Crypto::RuntimeTest();
     } catch (CryptoTestFailedException $e) {
         self::markTestSkipped('The environment cannot safely perform encryption with this cipher.');
     }
 }
開發者ID:SysBind,項目名稱:joomla-cms,代碼行數:14,代碼來源:JCryptCipherCryptoTest.php

示例2: Decrypt

 public static function Decrypt($ciphertext, $key)
 {
     Crypto::RuntimeTest();
     // Extract the HMAC from the front of the ciphertext.
     if (self::our_strlen($ciphertext) <= self::MAC_BYTE_SIZE) {
         throw new InvalidCiphertextException();
     }
     $hmac = self::our_substr($ciphertext, 0, self::MAC_BYTE_SIZE);
     if ($hmac === FALSE) {
         throw new CannotPerformOperationException();
     }
     $ciphertext = self::our_substr($ciphertext, self::MAC_BYTE_SIZE);
     if ($ciphertext === FALSE) {
         throw new CannotPerformOperationException();
     }
     // Regenerate the same authentication sub-key.
     $akey = self::HKDF(self::HASH_FUNCTION, $key, self::KEY_BYTE_SIZE, self::AUTHENTICATION_INFO);
     if (self::VerifyHMAC($hmac, $ciphertext, $akey)) {
         // Regenerate the same encryption sub-key.
         $keysize = self::KEY_BYTE_SIZE;
         $ekey = self::HKDF(self::HASH_FUNCTION, $key, $keysize, self::ENCRYPTION_INFO);
         // Extract the initialization vector from the ciphertext.
         self::EnsureFunctionExists("mcrypt_get_iv_size");
         $ivsize = mcrypt_get_iv_size(self::CIPHER, self::CIPHER_MODE);
         if ($ivsize === FALSE || $ivsize <= 0) {
             throw new CannotPerformOperationException();
         }
         if (self::our_strlen($ciphertext) <= $ivsize) {
             throw new InvalidCiphertextException();
         }
         $iv = self::our_substr($ciphertext, 0, $ivsize);
         if ($iv === FALSE) {
             throw new CannotPerformOperationException();
         }
         $ciphertext = self::our_substr($ciphertext, $ivsize);
         if ($ciphertext === FALSE) {
             throw new CannotPerformOperationException();
         }
         $plaintext = self::PlainDecrypt($ciphertext, $ekey, $iv);
         return $plaintext;
     } else {
         /*
          * We throw an exception instead of returning FALSE because we want
          * a script that doesn't handle this condition to CRASH, instead
          * of thinking the ciphertext decrypted to the value FALSE.
          */
         throw new InvalidCiphertextException();
     }
 }
開發者ID:deenison,項目名稱:joomla-cms,代碼行數:49,代碼來源:Crypto.php

示例3: mb_internal_encoding

<?php

// Set the encoding to something more "challenging."
$ret = mb_internal_encoding('UTF-8');
if ($ret === FALSE) {
    echo "Couldn't set encoding.";
    exit(1);
}
// Dump out the settings / encoding for future reference.
$val = ini_get("mbstring.func_overload");
echo "Settings: \n";
echo "    func_overload: " . $val . "\n";
echo "    mb_internal_encoding(): " . mb_internal_encoding() . "\n";
// Perform the tests.
require_once 'Crypto.php';
try {
    Crypto::RuntimeTest();
    echo "TEST PASSED!\n";
    exit(0);
} catch (CryptoTestFailedException $ex) {
    echo "TEST FAILED!\n";
    var_dump($ex);
    exit(1);
} catch (CannotPerformOperationException $ex) {
    echo "TEST FAILED\n";
    var_dump($ex);
    exit(1);
}
開發者ID:ZerGabriel,項目名稱:friendica,代碼行數:28,代碼來源:runtime.php


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