AES的加密解密实现
ECB有偏移量iv的时候
加密算法
encrypt: function (data) {
let key = '*************';
let iv = '********';
let encryptData = this.encryptByDESModeCBCUtf8to64(data, key, iv);
return encryptData
},
encryptByDESModeCBCUtf8to64: function (message, key, iv) {
let keyHex = CryptoJS.enc.Utf8.parse(key);
let ivHex = CryptoJS.enc.Utf8.parse(iv);
let encrypted = CryptoJS.DES.encrypt(message, keyHex, {
iv: ivHex,
mode: CryptoJS.mode.ECB,
padding: CryptoJS.pad.Pkcs7
})
return encrypted.ciphertext.toString(CryptoJS.enc.Hex);
},
解密算法
decrypt: function (data) {
let key = '*************';
let iv = '********';
let decryptData = this.decryptByDESModeCBCUtf8to64(data, key, iv);
return decryptData
},
decryptByDESModeCBCUtf8to64: function (message, key, iv) {
let keyHex = CryptoJS.enc.Utf8.parse(key);
let ivHex = CryptoJS.enc.Utf8.parse(iv);
let decrypted = CryptoJS.DES.decrypt({
ciphertext: CryptoJS.enc.Hex.parse(message)
}, keyHex, {
iv: ivHex,
mode: CryptoJS.mode.ECB,
padding: CryptoJS.pad.Pkcs7
})
return decrypted.toString(CryptoJS.enc.Utf8);
},
ECB没有偏移量iv的时候
function encrypt(text) {
return CryptoJS.AES.encrypt(text, CryptoJS.enc.Utf8.parse(key), {
mode: CryptoJS.mode.ECB,
padding: CryptoJS.pad.Pkcs7
}).toString()
}
// 解密
function decrypt(text) {
let decrypted = CryptoJS.AES.decrypt(text, CryptoJS.enc.Utf8.parse(key), {
mode: CryptoJS.mode.ECB,
padding: CryptoJS.pad.Pkcs7
});
return decrypted.toString(CryptoJS.enc.Utf8)
}
————————————————
版权声明:本文为CSDN博主「JSON_L」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/json_ligege/article/details/127788176
参考文章JS AES加密解密实现