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

wufei1232025-03-24PHP1

如何在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加解密效果?的详细内容,更多请关注知识资源分享宝库其它相关文章!

发表评论

访客

◎欢迎参与讨论,请在这里发表您的看法和观点。