本文演示如何用php實現與Java類似的AES加密解密功能。Java代碼通常使用AES算法,包含加密和解密方法。PHP實現需要選擇合適的函數并處理差異。
Java代碼用KeyGenerator生成密鑰,并通過SecretKeySpec用于Cipher對象。PHP可以使用openssl_encrypt和openssl_decrypt函數實現類似功能。但Java和PHP的密鑰生成方式不同,PHP通常使用預設密鑰或更安全的密鑰生成方法。
Java代碼的加密結果為十六進制字符串,解密需要將其轉換為字節數組。PHP代碼也需進行類似轉換。此外,Java代碼有完善的異常處理,PHP代碼也應注意異常處理。
以下PHP代碼實現了類似功能,使用AES-128-CBC模式,包含隨機IV向量的生成和處理:
立即學習“PHP免費學習筆記(深入)”;
class AESUtil { private static $key = "test"; // 默認密鑰 public static function encrypt($content, $key = null) { $key = $key ?? self::$key; $iv_size = openssl_cipher_iv_length('AES-128-CBC'); $iv = openssl_random_pseudo_bytes($iv_size); $encrypted = openssl_encrypt($content, 'AES-128-CBC', $key, OPENSSL_RAW_DATA, $iv); return strtoupper(bin2hex($iv . $encrypted)); } public static function decrypt($content, $key = null) { $key = $key ?? self::$key; $data = hex2bin($content); $iv_size = openssl_cipher_iv_length('AES-128-CBC'); $iv = substr($data, 0, $iv_size); $encrypted = substr($data, $iv_size); return openssl_decrypt($encrypted, 'AES-128-CBC', $key, OPENSSL_RAW_DATA, $iv); } } // 使用示例 $plaintext = "Hello, World!"; $encrypted = AESUtil::encrypt($plaintext); $decrypted = AESUtil::decrypt($encrypted); echo "原文: " . $plaintext . PHP_EOL; echo "加密后: " . $encrypted . PHP_EOL; echo "解密后: " . $decrypted . PHP_EOL;
這段PHP代碼使用openssl_encrypt和openssl_decrypt函數,以及AES-128-CBC模式。它處理了IV向量,確保與Java代碼類似的加解密效果。 注意:實際應用中,密鑰安全性至關重要,應使用更安全的密鑰管理機制。 默認密鑰“test”僅用于演示,切勿在生產環境中使用。
? 版權聲明
文章版權歸作者所有,未經允許請勿轉載。
THE END