总结
豆包 AI 助手文章总结

PHP如何实现与Java一致的AES加解密?

DDD
发布: 2025-03-27 08:48:32
原创
1015人浏览过

php 如何实现 aes 加解密与 java 一致?

在日常开发中,我们常常需要在不同编程语言之间实现一致的加密解密功能。最近,有一位开发者分享了一段 java 实现的 aes 加解密代码,并希望能在 php 中实现同样的效果。下面我们将详细探讨如何使用 php 来实现与 java 代码一致的 aes 加解密。

首先,我们需要理解 java 代码中的 aes 加解密实现细节。java 代码中使用了 aes 算法,并通过 keygenerator 和 securerandom 来生成密钥。加密时,数据被转换为十六进制字符串,解密时则将十六进制字符串转换回二进制数据进行解密。

接下来,我们来看如何在 php 中实现类似的功能。php 的 openssl 扩展提供了强大的加密功能,我们可以利用它来实现 aes 加解密。以下是参考代码:

class AESUtil
{
    private static $key = "test"; // 默认密钥

    /**
     * 加密函数
     *
     * @param string $content 要加密的数据
     * @param string|null $key 加密使用的密钥,如果未指定,则使用默认密钥
     * @return string 加密后的十六进制字符串
     */
    public static function encrypt($content, $key = null)
    {
        if (is_null($key)) { // 如果未指定密钥,则使用默认密钥
            $key = self::$key;
        }

        // 生成随机的初始化向量(IV)
        $iv_size = openssl_cipher_iv_length('AES-128-CBC');
        $iv = openssl_random_pseudo_bytes($iv_size);

        // 对数据进行加密
        $encrypted_data = openssl_encrypt($content, 'AES-128-CBC', $key, OPENSSL_RAW_DATA, $iv);

        // 将 IV 和加密后的数据连接起来,作为输出的结果
        $data_with_iv = $iv . $encrypted_data;
        return strtoupper(bin2hex($data_with_iv)); // 将结果转换为十六进制字符串并返回
    }

    /**
     * 解密函数
     *
     * @param string $content 要解密的数据(十六进制字符串)
     * @param string|null $key 解密使用的密钥,如果未指定,则使用默认密钥
     * @return string 解密后的数据
     */
    public static function decrypt($content, $key = null)
    {
        if (is_null($key)) { // 如果未指定密钥,则使用默认密钥
            $key = self::$key;
        }

        // 将输入的十六进制字符串转换为二进制数据
        $data_with_iv = hex2bin($content);

        // 从数据中提取 IV 和加密的数据
        $iv_size = openssl_cipher_iv_length('AES-128-CBC');
        $iv = substr($data_with_iv, 0, $iv_size);
        $encrypted_data = substr($data_with_iv, $iv_size);

        // 对数据进行解密
        $decrypted_data = openssl_decrypt($encrypted_data, 'AES-128-CBC', $key, OPENSSL_RAW_DATA, $iv);

        return $decrypted_data; // 返回解密后的数据
    }
}

// 使用示例
$plaintext = "Hello, World!";
$encrypted_text = AESUtil::encrypt($plaintext);
$decrypted_text = AESUtil::decrypt($encrypted_text);

echo "原文: " . $plaintext . PHP_EOL;
echo "加密后: " . $encrypted_text . PHP_EOL;
echo "解密后: " . $decrypted_text . PHP_EOL;
登录后复制

这段 php 代码使用了 aes-128-cbc 加密模式,并生成一个随机的 iv 向量作为参数传递给加解密函数。在加密时,iv 向量和加密后的数据一起进行编码,解密时先将编码后的字符串解码成 iv 向量和密文,然后再进行解密。这种方式可以确保 php 实现的 aes 加解密与 java 代码保持一致。

通过上述方法,我们可以实现与 java 代码一致的 aes 加解密效果。如果你有进一步的问题或需要其他帮助,欢迎继续提问。

立即学习PHP免费学习笔记(深入)”;

以上就是PHP如何实现与Java一致的AES加解密?的详细内容,更多请关注php中文网其它相关文章!

PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
相关标签:
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
豆包 AI 助手文章总结
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号