
数据安全在编程中至关重要。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免费学习笔记(深入)”;
以上就是如何在PHP中实现与Java相同的AES加解密效果?的详细内容,更多请关注php中文网其它相关文章!
PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号