• js AES加密 转 Base64 再转成urlEncode


       

    安装   crypto-js       项目地址:https://github.com/lzx-cloud/examples-h5/tree/main/aes

    运行命令:  cnpm install crypto-js --save

      新建脚本 tool.js

    const CryptoJS = require('crypto-js');  //引用AES源码js
    
    var key = CryptoJS.enc.Utf8.parse("123456");
    var iv = CryptoJS.enc.Utf8.parse("T(123456");
    
    //解密方法
    function Decrypt(word) {
    
      let encryptedHexStr = CryptoJS.enc.Base64.parse(word);
      let srcs = CryptoJS.enc.Base64.stringify(encryptedHexStr);
    
      let decrypt = CryptoJS.AES.decrypt(srcs, key, {
        iv: iv,
        mode: CryptoJS.mode.CBC,
        padding: CryptoJS.pad.Pkcs7
      });
      let decryptedStr = decrypt.toString(CryptoJS.enc.Utf8);
      return decryptedStr.toString();
    
    }
    
    //加密方法
    function Encrypt(word){
      let srcs = CryptoJS.enc.Utf8.parse(word);
      let encrypted = CryptoJS.AES.encrypt(srcs, key, {
        iv: iv,
        mode: CryptoJS.mode.CBC,
        padding: CryptoJS.pad.Pkcs7
      });
    
      let encryptedHexStr = CryptoJS.enc.Base64.stringify(encrypted.ciphertext);
      return encryptedHexStr.toString();
      // return encrypted.ciphertext.toString().toUpperCase();   //不需要加密base64的时候可以直接返回
    }
    
    exports.Decrypt = Decrypt;
    exports.Encrypt = Encrypt;

      新建脚本 然后引入tool.js即可

    const {Decrypt,Encrypt} = require('./tools');
    
    const en = Encrypt("20211109134330");
    
    console.dir("加密后:" + en);
    
    const de = Decrypt('TATKPwbeKuoV/SqsYb0cfw==');
    console.dir("解密后:" + de);
    
    console.dir("---------");
    console.dir(encodeURIComponent ("N8c15TVp+CIAQ5I3IHZQZw=="));
    console.dir(decodeURIComponent("N8c15TVp%2BCIAQ5I3IHZQZw%3D%3D"));
    
    console.dir("---------");
    console.dir(encodeURIComponent ("TATKPwbeKuoV/SqsYb0cfw=="));
    console.dir(decodeURIComponent("TATKPwbeKuoV%2FSqsYb0cfw%3D%3D"));
  • 相关阅读:
    Django项目:CMDB(服务器硬件资产自动采集系统)--01--01CMDB获取服务器基本信息
    rabbitmq 实现多个消费队列
    mssql附加的数据库查询的时候没有搜索权限
    mvc 返回json格式时间格式化
    HighChat动态绑定数据 数据后台绑定(四)
    双向绑定
    v-bind 属性绑定
    v-on 事件触发
    v-text和v-html绑定数据显示
    插值表达式
  • 原文地址:https://www.cnblogs.com/ZhiXing-Blogs/p/15528722.html
Copyright © 2020-2023  润新知