加密模式 openssl sm4_JAVA实现PHP的openssl_encrypt方法

导读:本文主要讨论如何通过 Java 方式实现 PHP 的 openssl_encrypt() 加密方法与 openssl_decrypt() 解密方法。本文例子加解密例子均采用 AES256 位 cbc 模式。

1f89cdb157486b31a057ba2e39039761.png

PHP利用openssl_encrypt实现数据的加密

f68287bc59f1dd58c216c8433b5ff818.png

openssl_encrypt 加密

  • $data:将被加密的明文。
  • $method:加解密方法,这里采用 AES-256-CBC,AES256位cbc模式的加密和解密
  • $KEY:加密秘钥。
  • $options :该值用于指定 openssl_encrypt() 数据返回格式。默认情况下返回Base64编码,当设置为 OPENSSL_RAW_DATA 时返回原数据。本文下面的Java实现将其默认为 0,(即返回Base64编码)
  • IV:要确保对 key 唯一。

上面的例子将字符串 &#

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
PHP5中,可以使用`openssl_encrypt`和`openssl_decrypt`函数来实现SM4算法的加密和解密。 下面是一个示例代码: ```php function sm4_encrypt($data, $key) { $iv = openssl_random_pseudo_bytes(openssl_cipher_iv_length('sm4-cbc')); $encrypted = openssl_encrypt($data, 'sm4-cbc', $key, OPENSSL_RAW_DATA, $iv); return base64_encode($iv . $encrypted); } function sm4_decrypt($data, $key) { $data = base64_decode($data); $iv = substr($data, 0, openssl_cipher_iv_length('sm4-cbc')); $encrypted = substr($data, openssl_cipher_iv_length('sm4-cbc')); return openssl_decrypt($encrypted, 'sm4-cbc', $key, OPENSSL_RAW_DATA, $iv); } // 测试 $data = "hello world"; $key = "this is a key"; $encrypted = sm4_encrypt($data, $key); $decrypted = sm4_decrypt($encrypted, $key); echo "加密后的数据: " . $encrypted . "\n"; echo "解密后的数据: " . $decrypted . "\n"; ``` 在这段代码中,`sm4_encrypt`函数使用`openssl_encrypt`函数对数据进行加密,然后用base64编码返回加密后的结果。`sm4_decrypt`函数则对base64解码后的数据进行解密,并返回解密后的结果。在测试中,我们使用了一个字符串作为数据,一个字符串作为密钥,然后对数据进行加密和解密。 需要注意的是,在使用SM4算法时,需要使用`sm4-cbc`算法模式,并且需要提供一个随机的初始化向量(IV)来增加加密的强度。在本例中,我们使用`openssl_random_pseudo_bytes`函数生成一个随机的IV。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值