执行Call to undefined function mcrypt_get_block_size()
时间: 2023-11-12 19:09:08 浏览: 159
PHP加密3DES报错 Call to undefined function: mcrypt_module_open() 如何解决
如果你在执行上述代码时遇到了 `Call to undefined function mcrypt_get_block_size()` 这个错误,那么说明你的 PHP 环境中没有安装 `mcrypt` 扩展库。
在 PHP 7.2.0 版本中,`mcrypt` 扩展库已被弃用并在 PHP 7.2.0 中被移除。因此,如果你使用的是 PHP 7.2.0 或更高版本,那么无法使用 `mcrypt` 扩展库。
为了解决这个问题,你可以使用下面的代码来替换上述代码中的 `mcrypt` 函数:
```php
<?php
/**
* AES加密
* @param string $data 要加密的数据
* @param string $key 密钥
* @param string $iv 初始化向量
* @return string
*/
function aes_encrypt($data, $key, $iv) {
// PKCS7Padding 填充方式
$block_size = 16;
$padding = $block_size - (strlen($data) % $block_size);
$data .= str_repeat(chr($padding), $padding);
// 加密
$method = 'aes-128-cbc';
$encrypted = openssl_encrypt($data, $method, $key, OPENSSL_RAW_DATA, $iv);
return base64_encode($encrypted);
}
/**
* AES解密
* @param string $data 要解密的数据
* @param string $key 密钥
* @param string $iv 初始化向量
* @return string
*/
function aes_decrypt($data, $key, $iv) {
// 解密
$method = 'aes-128-cbc';
$decrypted = openssl_decrypt(base64_decode($data), $method, $key, OPENSSL_RAW_DATA, $iv);
// 去掉 PKCS7Padding 填充
$padding = ord($decrypted[strlen($decrypted)-1]);
return substr($decrypted, 0, -$padding);
}
// 测试
$key = '1234567890123456'; // 密钥必须为16、24或32个字符
$iv = '1234567890123456'; // 初始化向量必须为16个字符
$data = 'Hello, world!';
$cipher_text = aes_encrypt($data, $key, $iv);
$plain_text = aes_decrypt($cipher_text, $key, $iv);
echo '明文: ' . $data . "\n";
echo '密文: ' . $cipher_text . "\n";
echo '解密后: ' . $plain_text . "\n";
```
需要注意的是,使用 `openssl_encrypt` 和 `openssl_decrypt` 函数进行加解密时,需要注意以下几点:
1. 对于 `aes-128-cbc` 加密算法,密钥必须为 16 个字符,初始化向量必须为 16 个字符,可以根据需要修改。
2. 在加密时需要进行 PKCS7Padding 填充,解密后需要去除填充。
3. 如果需要加密的数据不是 16 的整数倍,需要进行填充。填充的字节为缺少的字节数,填充的内容为缺少的字节数。例如,如果需要加密的数据为 `Hello, world!`,则缺少 5 个字节,需要填充 5 个字节,填充的内容为 `\x05\x05\x05\x05\x05`。
阅读全文