前端crypto-js aes加解密

背景

公司后端加解密使用的是 `aes` 的方式,当时找了好多前端加解密的库,最后决定使用 `crypto-js` 封装了加解密方法。

准备工作 

在前端项目中安装 crypto-js 包 

npm install crypto-js

具体使用

import CryptoJS from 'crypto-js'


const crpytoConfig = {
    AES_KEY: 'key',
    AES_IV: 'iv',
}


/**
 * @description aes加密
 * @param {string} word 需要加密的字符串
 */

const cryptoEncrypt = word => {
  const { AES_IV, AES_KEY } = crpytoConfig
  const key = CryptoJS.enc.Utf8.parse(AES_KEY)
  const iv = CryptoJS.enc.Utf8.parse(AES_IV)
  const srcs = CryptoJS.enc.Utf8.parse(word)
  let encrypted = '';

  encrypted = CryptoJS.AES.encrypt(srcs, key, {
      iv,
      mode: CryptoJS.mode.CBC,
      padding: CryptoJS.pad.Pkcs7
  })
  return encrypted.ciphertext.toString(CryptoJS.enc.Base64)
}


/**
 * @description aes解密
 * @param {string} word 需要解密的字符串
 */

const cryptoDecrypt = word => {
  const { AES_IV, AES_KEY } = crpytoConfig
  // 因为和我们公司后端加密得出的数据有些出入 所以这里做了字符替换才能正常进行加解密 所以下边这句视情况而定到底加不加
  const strWord = word.replace(/\_/g, '/').replace(/\-/g, '+')
  const key = CryptoJS.enc.Utf8.parse(AES_KEY)
  const iv = CryptoJS.enc.Utf8.parse(AES_IV)
  const encryptedHexStr = CryptoJS.enc.Base64.parse(strWord)
  const srcs = CryptoJS.enc.Base64.stringify(encryptedHexStr)
  let decrypt = ''

  decrypt = CryptoJS.AES.decrypt(srcs, key, {
    iv,
    mode: CryptoJS.mode.CBC,
    padding: CryptoJS.pad.Pkcs7
  })
  return decrypt.toString(CryptoJS.enc.Utf8).toString()
}



 
 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值