网站目标定位概念,做电商网站有什语言好,75欧rf射频线,c2c平台代表1. 需求
对用户密码加密存入数据库#xff0c;修改密码时取出密码在前端解密#xff08;保证密码前后端传输过程中为密文#xff09;。
文档地址#xff1a;CryptoJS - CryptoJS (gitbook.io)
2. 原代码
2.1 加密
var userpass 123456;
var aseKey 修改密码时取出密码在前端解密保证密码前后端传输过程中为密文。
文档地址CryptoJS - CryptoJS (gitbook.io)
2. 原代码
2.1 加密
var userpass 123456;
var aseKey 12345678;
var encrypt CryptoJS.AES.encrypt(userpass, CryptoJS.enc.Utf8.parse(aseKey), {mode: CryptoJS.mode.CBC,padding: CryptoJS.pad.Pkcs7
}).toString();
console.log(encrypt);2.2 解密
var encrypt 密文密码;
var aseKey 12345678;
var decrypt CryptoJS.AES.decrypt(encrypt, CryptoJS.enc.Utf8.parse(aseKey), {mode: CryptoJS.mode.CBC,padding: CryptoJS.pad.Pkcs7
}).toString(CryptoJS.enc.Utf8);
console.log(decrypt)3 问题
上述代码加密环节没有问题但是从数据库取出后的密文进行解密内容为空。
4 解决方案
添加偏移量iv: CryptoJS.enc.Utf8.parse(aseKey)
4.1 加密
var userpass 123456;
var aseKey 12345678;
var encrypt CryptoJS.AES.encrypt(userpass, CryptoJS.enc.Utf8.parse(aseKey), {// 添加偏移量iv: CryptoJS.enc.Utf8.parse(aseKey),mode: CryptoJS.mode.CBC,padding: CryptoJS.pad.Pkcs7
}).toString();
console.log(encrypt);4.2 解密
var encrypt 密文密码;
var aseKey 12345678;
var decrypt CryptoJS.AES.decrypt(encrypt, CryptoJS.enc.Utf8.parse(aseKey), {// 添加偏移量iv: CryptoJS.enc.Utf8.parse(aseKey),mode: CryptoJS.mode.CBC,padding: CryptoJS.pad.Pkcs7
}).toString(CryptoJS.enc.Utf8);
console.log(decrypt)5. 参考资料 [1] 不要再问我加密的问题了使用crypto-js中的AES加密方法连续多次加密/解密注意事项 [2] CryptoJS aes加密不要求密钥长度解密为空字符串的问题