vue在本地存储使用crypto-js加密、解密数据

一.安装依赖

npm  i  crypto-js

二.封装方法

/utils/aes.ts 封装加密、解密方法

import CryptoJS from "crypto-js";
const aesKey = "12345678";
export default {
  //加密
  encrypt(v: any) {
    if (v) {
      return CryptoJS.AES.encrypt(v, CryptoJS.enc.Utf8.parse(aesKey), {
        mode: CryptoJS.mode.ECB,
        padding: CryptoJS.pad.Pkcs7,
      }).toString();
    }
  },

  //解密
  decode(v: any) {
    if (v) {
      return CryptoJS.AES.decrypt(v, CryptoJS.enc.Utf8.parse(aesKey), {
        mode: CryptoJS.mode.ECB,
        padding: CryptoJS.pad.Pkcs7,
      }).toString(CryptoJS.enc.Utf8);
    }
  },
};

三.使用

在stores使用

加密信息 如果是对象的话需要先转换字符串再进行加密

let encrypt = aes.encrypt(token);
localStorage.setItem("token", encrypt);

let encrypt2 = aes.encrypt(JSON.stringify(data));
localStorage.setItem("loginInfo", encrypt2);

解密信息 如果是对象的话解密后再转换对象

token: aes.decode(localStorage.getItem("token")),

loginInfo: JSON.parse(aes.decode(localStorage.getItem("loginInfo"))),

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值