zoukankan      html  css  js  c++  java
  • 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

  • 相关阅读:
    求解答可用性测试记
    Teambition可用性测试记
    海丁网可用性测试记
    go语言的切片
    go语言的数组
    go语言的函数
    go语言的接口
    go语言的结构体
    go语言的flag
    创建二叉树和三种遍历
  • 原文地址:https://www.cnblogs.com/gqx-html/p/10750928.html
Copyright © 2011-2022 走看看