本站资源收集于互联网,不提供软件存储服务,每天免费更新优质的软件以及学习资源!

如何在PHP中实现与Java相同的AES加解密效果?

网络教程 app 1℃

如何在PHP中实现与Java相同的AES加解密效果

PHP与Java AES加解密一致性实现

数据安全在编程中至关重要。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加解密效果?的详细内容,更多请关注范的资源库其它相关文章!

转载请注明:范的资源库 » 如何在PHP中实现与Java相同的AES加解密效果?

喜欢 (0)