php5 openssl_encrypt sm4算法
时间: 2023-10-05 17:04:19 浏览: 135
在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。
阅读全文