前端使用crypto.js进行加密的函数代码
crypto-js是一个纯javascript写的加密算法类库,可以非常方便地在javascript进行MD5、SHA1、SHA2、SHA3、RIPEMD-160哈希散列,进行AES、DES、Rabbit、RC4、TripleDES加解密。
可以在这个GitHub的https://github.com/brix/crypto-js上下载该js,它可以单独引入所需要加密方式的js;也可以引入一个crypto-js.js这个文件,它相当于引入了所有的加密方式,我使用的就是后者一次引入所有的加密文件,这个文件也不是很大,还可以接受。
因为我的需求是加密可逆,具有一定的安全性(对安全性要求不高),所以使用DES或AES即可,我用的是AES:
functiongetAesString(data,key,iv){//加密
varkey=CryptoJS.enc.Utf8.parse(key);
variv=CryptoJS.enc.Utf8.parse(iv);
varencrypted=CryptoJS.AES.encrypt(data,key,
{
iv:iv,
mode:CryptoJS.mode.CBC,
padding:CryptoJS.pad.Pkcs7
});
returnencrypted.toString();//返回的是base64格式的密文
}
functiongetDAesString(encrypted,key,iv){//解密
varkey=CryptoJS.enc.Utf8.parse(key);
variv=CryptoJS.enc.Utf8.parse(iv);
vardecrypted=CryptoJS.AES.decrypt(encrypted,key,
{
iv:iv,
mode:CryptoJS.mode.CBC,
padding:CryptoJS.pad.Pkcs7
});
returndecrypted.toString(CryptoJS.enc.Utf8);
}
functiongetAES(data){//加密
varkey='AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA';//密钥
variv='1234567812345678';
varencrypted=getAesString(data,key,iv);//密文
varencrypted1=CryptoJS.enc.Utf8.parse(encrypted);
returnencrypted;
}
functiongetDAes(data){//解密
varkey='AAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA';//密钥
variv='1234567812345678';
vardecryptedStr=getDAesString(data,key,iv);
returndecryptedStr;
}
key和iv我们都可以更换,但是需要保证的是加解密的key和iv保持一致
到此这篇关于前端使用crypto.js进行加密的函数代码的文章就介绍到这了,更多相关crypto.js加密内容请搜索毛票票以前的文章或继续浏览下面的相关文章希望大家以后多多支持毛票票!
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。