前端使用crypto.js進行加密
https://www.cnblogs.com/lz2017/p/8046816.html
最近我在前端使用Cookies保存密碼的時候需要前端來進行加密工作,接觸到crypto這個js,使用還算簡單,在這里記錄一下。
可以在這個GitHub的https://github.com/brix/crypto-js上下載該js,它可以單獨引入所需要加密方式的js;也可以引入一個crypto-js.js 這個文件,它相當於引入了所有的加密方式,我使用的就是后者一次引入所有的加密文件,這個文件也不是很大,還可以接受。
因為我的需求是密碼可逆,有一定的安全性,所以使用DES或AES即可,我是用的就是AES,正好網上有一個使用AES的例子,直接拿來用了
function getAesString(data,key,iv){//加密
var key = CryptoJS.enc.Utf8.parse(key);
var iv = CryptoJS.enc.Utf8.parse(iv);
var encrypted =CryptoJS.AES.encrypt(data,key,
{
iv:iv,
mode:CryptoJS.mode.CBC,
padding:CryptoJS.pad.Pkcs7
});
return encrypted.toString(); //返回的是base64格式的密文
}
function getDAesString(encrypted,key,iv){//解密
var key = CryptoJS.enc.Utf8.parse(key);
var iv = CryptoJS.enc.Utf8.parse(iv);
var decrypted =CryptoJS.AES.decrypt(encrypted,key,
{
iv:iv,
mode:CryptoJS.mode.CBC,
padding:CryptoJS.pad.Pkcs7
});
return decrypted.toString(CryptoJS.enc.Utf8);
}
function getAES(data){ //加密
var key = 'AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA'; //密鑰
var iv = '1234567812345678';
var encrypted =getAesString(data,key,iv); //密文
var encrypted1 =CryptoJS.enc.Utf8.parse(encrypted);
return encrypted;
}
function getDAes(data){//解密
var key = 'AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA'; //密鑰
var iv = '1234567812345678';
var decryptedStr =getDAesString(data,key,iv);
return decryptedStr;
}
key和iv我們都可以更換,但是需要保證的是加解密的key和iv保持一致

