PHP aes アルゴリズム

WBOY
WBOYオリジナル
2016-07-25 08:51:081139ブラウズ
PHP aes算法
                   
                               
                                       
                                       
            
  1. function aes128cbcEncrypt($key, $text)
  2. {
  3. /**
  4. * 暗号を開く
  5.      */
  6. $td = mcrypt_module_open(MCRYPT_RIJNDAEL_128, '', MCRYPT_MODE_CBC, '');
  7. if (! $td)
  8. {
  9. throw new GeneralSecurityException('Invalid mcrypt cipher, check your libmcrypt library and php-mcrypt extension');
  10. }
  11. // Windows には /dev/rand がないため、MCRYPT_DEV_RANDOM を MCRYPT_RAND に置き換えました :)
  12. srand((double)microtime () * 1000000);
  13. $iv = mcrypt_create_iv(mcrypt_enc_get_iv_size($td), MCRYPT_RAND);
  14. /**
  15. * 暗号化を初期化します
  16.      */
  17. mcrypt_generic_init($td, $key, $iv);
  18. /**
  19. * データを暗号化します
  20.       */
  21. $encrypted = mcrypt_generic($td, $text);
  22. /**
  23. * 暗号化ハンドラーを終了します
  24.      */
  25. mcrypt_generic_deinit($td);
  26. /**
  27. * AES-128-CBC 暗号化。  IV は、暗号文の最初の 16 バイト
  28. * として返されます。
  29.      */
  30. return $iv 。 $encrypted;
  31. }
  32. function aes128cbcDecrypt($key, $encrypted_text)
  33. {
  34. /**
  35. * 暗号を開く
  36.      */
  37. $td = mcrypt_module_open(MCRYPT_RIJNDAEL_128, '', MCRYPT_MODE_CBC, '');
  38. if (is_callable( ' mb_substr'))
  39. {
  40. $iv = mb_substr($encrypted_text, 0, Crypto_CIPHER_BLOCK_SIZE, 'latin1');
  41. }
  42. else
  43. {
  44. $iv = substr($encrypted_text, Crypto_CIPHER_BLOCK_SIZE);
  45. }
  46. /**
  47. * 復号化のために暗号化モジュールを初期化します
  48.      */
  49. mcrypt_generic_init($td, $key, $iv);
  50. /**
  51. * 暗号化された文字列を復号化します
  52.      */
  53. if (is_callable('mb_substr'))
  54. {
  55. $encrypted = mb_substr($encrypted_text, Crypto_CIPHER_BLOCK_SIZE, mb_strlen($encrypted_text, 'latin1'), 'latin1');
  56. }
  57. else
  58. {
  59. $encrypted = substr($encrypted_text, Crypto_CIPHER_BLOCK_SIZE);
  60. }
  61. $decrypted = generic($td, $encrypted);
  62. / **
  63. * 復号化ハンドルを終了し、モジュールを閉じます
  64.      */
  65. mcrypt_generic_deinit($td);
  66. mcrypt_module_close($td);
  67. /**
  68. * 文字列を表示
  69.      */
  70. return trim($decrypted);
  71. }
  72. define('Crypto_CIPHER_BLOCK_SIZE', 16);
  73. $a = aes128cbcEncrypt('pass', 'this is text');
  74. echobase64_encode($a) 。 "/r/n";
  75. $b = aes128cbcDecrypt('pass', $a);
  76. echo $b 。 "/r/n";
  77. $c = aes128cbcDecrypt('pass',base64_decode(base64_encode($a)));
  78. echo $c 。 "/r/n";
  79. ?>
复制發


声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。