本文实例讲述了PHP7实现和CryptoJS的AES加密方式互通。分享给大家供大家参考,具体如下:
PHP类:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
|
class AES
{
/**
*
* @param string $string 需要加密的字符串
* @param string $key 密钥
* @return string
*/
public static function encrypt( $string , $key )
{
// openssl_encrypt 加密不同Mcrypt,对秘钥长度要求,超出16加密结果不变
$data = openssl_encrypt( $string , 'AES-128-ECB' , $key , OPENSSL_RAW_DATA);
return base64_encode ( $data );
}
/**
* @param string $string 需要解密的字符串
* @param string $key 密钥
* @return string
*/
public static function decrypt( $string , $key )
{
return openssl_decrypt( base64_decode ( $string ), 'AES-128-ECB' , $key , OPENSSL_RAW_DATA);
}
/**
* 获取秘钥
* @return string
*/
public static function getSecretKey()
{
$str = 'xxx' ; //生成16位的字符窜
return $str ;
}
}
|
JS的写法:
1
2
3
4
5
6
7
8
9
10
11
12
13
|
<script type= "text/javascript" src= "./bower_components/crypto-js/crypto-js.js" ></script>
<script type= "text/javascript" >
AesKey = 'xxxxx' ; //加密时用的key,跟php一样
message= 'xxxxxxx' ; //加密后的字符窜
var ECBOptions = {
mode: CryptoJS.mode.ECB,
padding: CryptoJS.pad.Pkcs7
};
var key = CryptoJS.enc.Utf8.parse(AesKey);
var bytes = CryptoJS.AES.decrypt(message, key,ECBOptions);
var originalText = bytes.toString(CryptoJS.enc.Utf8);
console.log(originalText)
</script>
|
PS:关于加密解密感兴趣的朋友还可以参考本站在线工具:
文字在线加密解密工具(包含AES、DES、RC4等):https://tool.zzvips.com/t/txtencode/
MD5在线加密工具:https://tool.zzvips.com/t/md5/
在线Escape加密、解密工具:https://tool.zzvips.com/t/escape/
在线sha1/sha224/sha256/sha384/sha512加密工具:https://tool.zzvips.com/t/sha/
希望本文所述对大家PHP程序设计有所帮助。
原文链接:https://blog.csdn.net/LCRxxoo/article/details/89680346