如何在PHP中实现与Java相同的AES加解密效果?(效果.加解密.如何在.Java.PHP...)
数据安全在编程中至关重要。AES(高级加密标准)是一种广泛应用的对称加密算法。本文将探讨如何使用PHP的OpenSSL扩展实现与Java javax.crypto 包相同的AES加解密效果。
我们将采用AES-128-CBC模式,并生成随机初始化向量(IV)以增强安全性。 加密后的数据与IV一起存储,解密时需先分离IV和密文。
以下PHP代码演示了该实现:
class AESUtil { private static $key = "test"; // 默认密钥 /** * AES加密 * @param string $content 待加密数据 * @param string|null $key 密钥 (可选,使用默认密钥) * @return string 十六进制加密结果 */ public static function encrypt(string $content, ?string $key = null): string { $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)); } /** * AES解密 * @param string $content 十六进制加密数据 * @param string|null $key 密钥 (可选,使用默认密钥) * @return string 解密结果 */ public static function decrypt(string $content, ?string $key = null): string { $key = $key ?? self::$key; $binary = hex2bin($content); $iv_size = openssl_cipher_iv_length('AES-128-CBC'); $iv = substr($binary, 0, $iv_size); $encrypted = substr($binary, $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代码与Java的AES-128-CBC实现具有可比性。通过随机生成IV并将其与密文一起存储和处理,确保了加密过程的安全性。 记住替换 "test" 为你的实际密钥。 在生产环境中,务必使用更安全的密钥生成和管理方法。
以上就是如何在PHP中实现与Java相同的AES加解密效果?的详细内容,更多请关注知识资源分享宝库其它相关文章!