crypto-js进行字符串的加密解密(可搭配localStorage使用)

本文介绍如何利用crypto-js库实现AES加密与解密,并结合localStorage进行数据的安全存储与读取。具体步骤包括:设置十六进制密钥与偏移量、定义加密解密函数、读写localStorage中加密数据。
摘要由CSDN通过智能技术生成

1.导入crypto-js

导入crypto-js然后,需要设置自己的秘钥

import CryptoJS from 'crypto-js'

// 十六位十六进制数作为密钥
const SECRET_KEY = CryptoJS.enc.Utf8.parse('1234123412341234')
// 十六位十六进制数作为密钥偏移量
const SECRET_IV = CryptoJS.enc.Utf8.parse('1234123412341234')

2.加密

对字符串进行加密

/**
 * 加密方法
 * @param data - 数据
 */
function encrypt(data: string) {
  const dataHex = CryptoJS.enc.Utf8.parse(data)
  const encrypted = CryptoJS.AES.encrypt(dataHex, SECRET_KEY, {
    iv: SECRET_IV,
    mode: CryptoJS.mode.CBC,
    padding: CryptoJS.pad.Pkcs7
  })
  return encrypted.ciphertext.toString()
}

3.解密

对字符串进行解密

/**
 * 解密方法
 * @param data - 数据
 */
function decrypt(data: string) {
  const encryptedHexStr = CryptoJS.enc.Hex.parse(data)
  const str = CryptoJS.enc.Base64.stringify(encryptedHexStr)
  const decrypt = CryptoJS.AES.decrypt(str, SECRET_KEY, {
    iv: SECRET_IV,
    mode: CryptoJS.mode.CBC,
    padding: CryptoJS.pad.Pkcs7
  })
  const decryptedStr = decrypt.toString(CryptoJS.enc.Utf8)
  return decryptedStr.toString()
}

4. 搭配localStorage使用

从localStorage读取数据

/**
 * 从localStorage读取数据
 * @param dataName - localStorage中key值
 */
const getData = (dataName: string) => {
  try {
    const rlt = localStorage.getItem(dataName)
    if (rlt === null) return null
    return decrypt(rlt)
  } catch (err) {
    throw new Error('localStorage数据获取错误')
  }
}

存数据至localStorage

/**
 * 存数据至localStorage
 * @param dataName - localStorage中key值
 * @param text - 存储的数据
 */
const setData = async (dataName: string, text: string) => {
  localStorage.setItem(dataName, encrypt(text))
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值