CryptoJS 的一些方法
安装
Node.js 安装
npm install crypto-js
浏览器 安装
<script type="text/javascript" src="path-to/bower_components/crypto-js/crypto-js.js"></script>
<script type="text/javascript">
var encrypted = CryptoJS.AES(...);
var encrypted = CryptoJS.SHA256(...);
</script>
针对 AES 加密
介绍
在 CryptoJS 中,所有的加密操作和字节数组都由 WordArray 类型表示。CryptoJS 的加密和解密过程本质上都在处理字节数据(WordArray),所以无论你使用的是哪种加密算法,解密后的结果仍然是 字节数组(WordArray 对象)。所有通过 CryptoJS 加密的算法(如 AES、DES、Triple DES、RC4、Rabbit 等)都返回一个 WordArray 对象,它们的解密过程同样返回一个 WordArray 类型的数据。因此,你可以对这些算法的解密结果使用相同的 .toString() 方法来获取不同的编码格式。
加密算法 AES (暂时只了解 AES)
加密
加密函数的参数是:(明文字符串, 密钥字符串,可选参数对象),返回密文字符串。
加密函数是:Cryptojs.AES.encrypt,Cryptojs.DES.encrypt``,Cryptojs.Rabbit.encrypt,Cryptojs.RC4.encrypt,Cryptojs.TripleDES.encrypt
CryptoJS 支持以下加密模式:
- CBC (the default)
- CFB
- CTR
- OFB
- ECB
CryptoJS 支持以下填充方式:
- Pkcs7 (the default)
- Iso97971
- AnsiX923
- Iso10126
- ZeroPadding
- NoPadding
CryptoJS.AES.encrypt('Message', 'Secret Passphrase', {
mode: CryptoJS.mode.CFB,
padding: CryptoJS.pad.AnsiX923,
});
解密
解密函数的参数是:(密文字符串, 密钥字符串,可选参数对象),返回的结果必须用.toString(CryptoJS.enc.Utf8)转为明文。
解密函数是:CryptoJS.AES.decrypt,CryptoJS.DES.decrypt,CryptoJS.Rabbit.decrypt,CryptoJS.RC4.decrypt,CryptoJS.TripleDES.decrypt
CryptoJS 支持以下解密模式:
- CBC (the default)
- CFB
- CTR
- OFB
- ECB
CryptoJS 支持以下填充方式:
- Pkcs7 (the default)
- Iso97971
- AnsiX923
- Iso10126
- ZeroPadding
- NoPadding
CryptoJS.AES.decrypt('Message', 'Secret Passphrase' ,{
mode: CryptoJS.mode.CFB,
padding: CryptoJS.pad.AnsiX923
});
API
初始化
var wordArray = CryptoJS.lib.WordArray.create();//创建一个空的 WordArray对象
WordArray 对象 -> 16 进制字符串
var string = WordArray.toString(); // 默认CrytoJS.enc.Hex 即16进制字符串
var string = WordArray.toString(CrytoJS.enc.Utf8); // 转换成utf-8字符串
16 进制字符串转 -> WordArray 对象
var WordArray = CryptoJS.enc.hex.parse(hexString);
var WordArray = crtptoJS.enc.Utf8.parse(utf8String);
WordArray 对象转 -> Base64 字符串
var base64String = CryptoJS.enc.Base64.stringify(wordArray);
Base64 -> WordArray 对象
var WordArray = CryptoJS.en.Base64.parse(base64String);