openssl函数替换mcrypt函数加密解密
网上有很多示例,可以替换大部分场景,但对于其中细节却并未说明。同样,简单地使用网上示例在某种代码场景下有可能导致代码替换前后的兼容问题。在php7开发中,使用mcrypt相关函数可以很方便地进行AES加、解密操作,但是PHP7.1中废弃了mcrypt扩展,所以必需寻找另一种实现。在迁移手册中已经指出了用openssl代替mcrypt,但未给出具体示例。
以下是两者的区别及openssl替换mcrypt的方法:
替代
$key = ‘-2i61^’;
$iv = ‘&11r2(*3’;
$data = “123456789”; //要加密的数据
if(PHP_VERSION<5.6){
$a= base64_encode(mcrypt_encrypt(MCRYPT_3DES,$key,$data,MCRYPT_MODE_CBC,$iv));
echo ‘mcrypt_encrypt:’.$a.'<br>’;
//rtrim 移除字符串右侧的空白字符
$decrypt = rtrim(mcrypt_decrypt(MCRYPT_3DES,$key,base64_decode($a),MCRYPT_MODE_CBC,$iv),’\0′);
echo ‘mcrypt_decrypt:’.$decrypt.'<br>’;
} //使用mcrypt函数来对比
$len = strlen($data);
if($len%8){
$data = str_pad($data,$len+8-$len%8,”\0″);
}//使用空字符填充字符串的右侧,使字符串位数变为8的倍数
$b = base64_encode(openssl_encrypt($data,’DES-EDE3-CBC’,$key,OPENSSL_RAW_DATA|OPENSSL_NO_PADDING,$iv));
echo “openssl_encrypt:”.$b. ‘<br>’;
$decrypt = openssl_decrypt(base64_decode($b),’DES-EDE3-CBC’,$key,OPENSSL_RAW_DATA|OPENSSL_NO_PADDING,$iv);
echo ‘openssl_decrypt:’.$decrypt.'<br>’;
运行结果
mcrypt_encrypt:O4/3PssvAkrYtIlhbQEr+g==
mcrypt_decrypt:123456789
openssl_encrypt:O4/3PssvAkrYtIlhbQEr+g==
openssl_decrypt:123456789
然后来个对比,看看这两个函数的速度:
$key = ‘-2i61^’;
$iv = ‘&11r2(*3’;
$data = “123456789”;
if(PHP_VERSION<5.6){
$start = microtime(true);
for($i=0;$i<10000;$i++){
$a= base64_encode(mcrypt_encrypt(MCRYPT_3DES,$key,$data,MCRYPT_MODE_CBC,$iv));
}
echo ‘mcrypt_time:’; echo microtime(true)-$start.'<br>’;
echo ‘mcrypt_encrypt’.$a.'<br>’;
$decrypt = rtrim(mcrypt_decrypt(MCRYPT_3DES,$key,base64_decode($a),MCRYPT_MODE_CBC,$iv),’\0′);
echo ‘mcrypt_decrypt’.$decrypt.'<br>’;
}
$start = microtime(true);
for($i=0;$i<10000;$i++){
$len = strlen($data);
if($len%8){
$data = str_pad($data,$len+8-$len%8,”\0″);
}
$b = base64_encode(openssl_encrypt($data,’DES-EDE3-CBC’,$key,OPENSSL_RAW_DATA|OPENSSL_NO_PADDING,$iv));
}
echo “openssl_time:”; echo microtime(true)-$start . ‘<br>’;
echo “openssl_encrypt:”.$b. ‘<br>’;
$decrypt = openssl_decrypt(base64_decode($b),’DES-EDE3-CBC’,$key,OPENSSL_RAW_DATA|OPENSSL_NO_PADDING,$iv);
echo ‘openssl_decrypt’.$decrypt.'<br>’;
结果
mcrypt_time:1.8425710201263
mcrypt_encryptO4/3PssvAkrYtIlhbQEr+g==
mcrypt_decrypt123456789
openssl_time:0.023201942443848
openssl_encrypt:O4/3PssvAkrYtIlhbQEr+g==
openssl_decrypt123456789
常见问题FAQ
- 程序仅供学习研究,请勿用于非法用途,不得违反国家法律,否则后果自负,一切法律责任与本站无关。
- 请仔细阅读以上条款再购买,拍下即代表同意条款并遵守约定,谢谢大家支持理解!