前端 crypto-js aes 加解密

  1. 使用场景
  • 前端在用户本地储存敏感信息时加密保护
  • 前后端传输账号密码时可以进行加密处理
  1. 安装npm包
npm install crypto-js 
  1. 封装调用
// 存在 src/utils/secret.js

封装

const CryptoJS = require('crypto-js');  //引用AES源码js
    
// key iv 自己设置16即可,位置要对应上;
const key = CryptoJS.enc.Utf8.parse("1234123412ABCDEF");  //十六位十六进制数作为密钥
const iv = CryptoJS.enc.Utf8.parse('ABCDEF1234123412');   //十六位十六进制数作为密钥偏移量

//解密方法
function Decrypt(word) {
    let encryptedHexStr = CryptoJS.enc.Hex.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 });
    return encrypted.ciphertext.toString().toUpperCase();
}

export default {
    Decrypt ,
    Encrypt
}
// 调用
import secret from '../utils/secret.js'
// 在created里面测试
// 加密

console.log('加密---',secret.Encrypt('{"No":18737002003,"password": "992chuan"}'));
log:'6AEF3615CF82FAC75E34E416E19929C2E96A384A7C9BE9C2CC27E10C26AF567E64A31A5F4EDA3EB7229597275CBF8BEF'

// 解密

console.log(secret.Decrypt('6AEF3615CF82FAC75E34E416E19929C2E96A384A7C9BE9C2CC27E10C26AF567E64A31A5F4EDA3EB7229597275CBF8BEF'));
log:{"No":18737002003,"password": "992chuan"}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

尤山海

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值