您好,登錄后才能下訂單哦!
小編給大家分享一下php7.0中openssl_encrypt加密的方法,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
php5.4版本mcrypt_encryp提升到php7.0 openssl_encrypt,加密字段不一樣。
使用的加密字段和key,加密模式都一樣,可是加密后的數據不一樣,
這是代碼片段
<?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=
下面是使用php7.0版本以上不支持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"; >
加密后是gHXA5vo5hEMxjthYNq/gbtwwm1TlRzsRBI64TrEo3P8=
1.gHXA5vo5hEMxjthYNq/gborXWNETPw0rYEb2FspAYzc=
2.gHXA5vo5hEMxjthYNq/gbtwwm1TlRzsRBI64TrEo3P8=
是不是不一樣,這樣加密出來的數據不仔細查看,會認為是一樣的數據。
要想保證加密一樣,將php7.0的代碼修改如下
<?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=,這樣就保持一致了。
以上是php7.0中openssl_encrypt加密的方法的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。