AES的加密和解密(CryptoJS)

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);
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值