js 使用AES加解密
在项目中安装 crypto.js。
npm install crypto-js
在项目中新建文件夹 utils新建工具类文件引入crypto-js文件
import CryptoJS from 'crypto-js'
初始化16位密钥 及 16位iv(密钥偏移量)解密方法
export const Decrypt = (word) => {
let encryptedHexStr = CryptoJS.enc.Hex.parse(word);
let srcs = CryptoJS.enc.Base64.stringify(encryptedHexStr);
let decrypt = CryptoJS.AES.decrypt(srcs, key, { iv: iv, mode: CryptoJS.mode.CBC, padding: CryptoJS.pad.Pkcs7 });
let decryptedStr = decrypt.toString(CryptoJS.enc.Utf8);
return decryptedStr.toString();
}
加密方法
export const Encrypt = (word) => {
let srcs = CryptoJS.enc.Utf8.parse(word);
let encrypted = CryptoJS.AES.encrypt(srcs, key, { iv: iv, mode: CryptoJS.mode.CBC, padding: CryptoJS.pad.Pkcs7 });
return encrypted.ciphertext.toString().toUpperCase();
}
加密 数字 123456789 代码中测试测试: 在线工具中测试: 至于为什么在工具上方选择不是初始化的选项。 主要是因为,代码中明显可以看到 加密使用的是UTF-8,并且模式使用的是CBC 填充padding 则使用的是PKCS7
解密时候可以看到 输出使用的是HEX,模式依旧是CBC 填充是PKCS7 。转换字符为UTF8 故此,验证完毕。
|