PHP如何實現與Java類似的AES加密解密功能?

PHP如何實現與Java類似的AES加密解密功能?

本文演示如何用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
喜歡就支持一下吧
點贊9 分享