ホームページ >バックエンド開発 >PHPチュートリアル >AES暗号化/復号化によるbin2hexとhex2binの切り替えなどのPHP
この記事では主に、PHP での AES 暗号化/復号化による bin2hex と hex2bin 間の切り替えの問題について説明します。これは良い参考値であり、皆様のお役に立てれば幸いです。編集者をフォローして見てみましょう。
<?php /** * 通过AES加密请求数据 * * @param array $query * @return string */ function AESEncryptRequest($encryptKey, $query){ return $this->encrypt_pass($query,$encryptKey); } // 加密 function encrypt_pass($input, $key) { $size = mcrypt_get_block_size(MCRYPT_RIJNDAEL_128, MCRYPT_MODE_ECB); $input = pkcs5_pad($input, $size); $td = mcrypt_module_open(MCRYPT_RIJNDAEL_128, '', MCRYPT_MODE_ECB, ''); $iv = '0102030405060708'; mcrypt_generic_init($td, $key, $iv); $data = mcrypt_generic($td, $input); mcrypt_generic_deinit($td); mcrypt_module_close($td); $data = bin2hex($data); return $data; } //填充 function pkcs5_pad ($text, $blocksize) { $pad = $blocksize - (strlen($text) % $blocksize); return $text . str_repeat(chr($pad), $pad); } /** * 通过AES解密请求数据 * * @param array $query * @return string */ function AESDecryptResponse($encryptKey,$data){ return $this->decrypt_pass($data,$encryptKey); } // 解密 function decrypt_pass($sStr, $sKey) { $iv = '0102030405060708'; $decrypted= mcrypt_decrypt( MCRYPT_RIJNDAEL_128, $sKey, hex2bin($sStr), MCRYPT_MODE_ECB, $iv ); $dec_s = strlen($decrypted); $padding = ord($decrypted[$dec_s-1]); $decrypted = substr($decrypted, 0, -$padding); return $decrypted; }
関連する推奨事項:
以上がAES暗号化/復号化によるbin2hexとhex2binの切り替えなどのPHPの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。