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 分享