如何加密php7.0 openssl_encrypt
![]()
现在有加密了。使用的加密字段和密钥以及加密方式相同,但加密的数据不同。
这是代码片段
<?php
$privateKey = "qewrvxffbfdhsfdgh";
$iv = "234253454354352";
$data = "测试用的数据";
$encrypted = mcrypt_encrypt(MCRYPT_RIJNDAEL_128, $privateKey, $data, MCRYPT_MODE_CBC, $iv);
echo(base64_encode($encrypted));
echo "\n";
>加密后的数据为gHXA5vo5hEMxjthYNq /gborXWNETPw0rYEb2FspAYzc=
以下是使用mcrypt_encryp函数进行加密的代码,以上版本不支持
<?php
$privateKey = "qewrvxffbfdhsfdgh";
$iv = "234253454354352";
$data = "测试用的数据";
$encrypted= openssl_encrypt($data,'aes-128-cbc', $privateKey, OPENSSL_RAW_DATA, $iv);
echo(base64_encode($encrypted));
echo "\n";
>加密后为gHXA5vo5 hEMxjth YNq/gbtwwm1TlRzsRBI64TrEo3P8 =
1.gHXA5vo5hEMxjthY Nq/gborXWNETPw0rYEb2FspAYzc=
2.gHXA5vo5hEMxjthYNq/gbtwwm1Tl RzsRBI64TrEo3P8=
有什么不同吗?如果不仔细检查以这种方式编码的数据,则将假定它们是相同的数据。
为了保证编码一致,将代码改成如下
<?php
$privateKey = "qewrvxffbfdhsfdgh";
$iv = "234253454354352";
$data = "测试用的数据";
if (strlen($data) % 16) {
$data = str_pad($data,strlen($data) + 16 - strlen($data) % 16, "\0");
}
$encrypted= openssl_encrypt($data, 'AES-128-CBC',$privateKey,OPENSSL_NO_PADDING,$iv);
echo (base64_encode($encrypted));编码后的数据为gHXA5vo5hEMxjthYNq/gborXWNETPw0rYEb2FspAYzc=,这样就一致了。
版权声明
本文仅代表作者观点,不代表Code前端网立场。
本文系作者Code前端网发表,如需转载,请注明页面地址。
code前端网
