cryptoJS

 

CryptoJS通俗的来讲是为了安全性,将前端传递到后端的参数加密

  1. 加密/解密方法(对称加密算法)
  • AES 高级加密标准,是下一代的加密算法标准,速度快,安全级别高
  • DES 数据加密标准,适用于大量数据加密
  • TripleDES 是DES的增强版
  • RC4 流加密算法,密钥长度可变
  • HmacSHA1 键控哈希算法(密钥与消息数据混合)
1.加密
CryptoJS.AES.encrypt(srcs, key, { iv: iv, mode: CryptoJS.mode.CBC, padding: CryptoJS.pad.Pkcs7 });
CryptoJS.AES.decrypt(encryptedBase64Str, key, { mode: CryptoJS.mode.CBC, padding: CryptoJS.pad.Pkcs7 });
注解:// encrypt加密 / decrypt解密
// srcs 加密的字符串
   // key 密钥 值得注意的是密钥的长度,对称加密算法AES-128-CBC算法,数据采用 PKCS#7 填充 , 因此这里的 key 需要为16位!
   // iv 密钥偏移量
   // mode 加密模式 【CBC ECB CFB OFB CTRGladman(CTR)】
   // paddig 填充方式 【 NoPadding ZeroPadding Pkcs7(Pkcs5) Iso10126 Iso97971 AnsiX923 】


srcs值 有四种方法
let srcs = CryptoJS.enc.Utf8.parse(utf8String);
let srcs = CryptoJS.enc.Latin1.parse(latin1String);
let srcs = CryptoJS.enc.Hex.parse(hexString);
let srcs = CryptoJS.enc.Base64.parse(base64String);
encryptedBase64Str值 有四种方法 
let encryptedBase64Str = CryptoJS.enc.utf8.stringify(encryptedHexStr);
let encryptedBase64Str = CryptoJS.enc.Latin1.stringify(latin1String);
let encryptedBase64Str = CryptoJS.enc.Hex.stringify(hexString);
let encryptedBase64Str = CryptoJS.enc.Base64.stringify(base64String);

可参考https://www.jianshu.com/p/a47477e8126a示例链接

github链接: https://github.com/brix/crypto-js

posted @ 2019-04-22 16:28  小短腿奔跑吧  阅读(1342)  评论(0编辑  收藏  举报