数据传输的AES加解密

290 阅读1分钟

记录一个问题,以前也遇到过,只是久了不碰就容易忘记。

安装

npm install crypto-js 

先说这玩意都有什么东西

  1. 编码(CryptoJS.enc),编码分Base64和Hex的,这个你要跟后端确定是用的哪个;
  2. 模式(CryptoJS.mode),模式一共有五种,ECB,CBC,CTR,CFB,OFB的,这个你也要跟后端确认是用哪个,一般常用的是前两个;
  3. 填充(CryptoJS.pad),填充模式一共有六种,Pkcs7,Pkcs5,NoPadding,Ansix923,Iso10126,ZeroPadding这几种也要跟后端确认用哪个,一般常用的就是前两个;
  4. 秘钥(key),前后约定好的一个秘钥字符串
  5. 偏移量(iv),也是前后约定好的一个字符串

再说下常见的处理方式(现在公司没有这么操作),一般数据传输加密也就是前端加密后,后端拿到直接加盐在加密存数据库的,后端返回给前端在解密呈现

上代码

import CryptoJS from 'crypto-js'
const KEY = CryptoJS.enc.Utf8.parse(`123456`) // 密钥
const IV = CryptoJS.enc.Utf8.parse('123123') // 偏移量
/**
 * AES加密
 * @param word
 * @param keyStr
 * @param ivStr
 * @returns Hex
 */
export const Encrypt = (word, keyStr, ivStr) => {
  let key = KEY
  let iv = IV

  if (keyStr) {
    key = CryptoJS.enc.Utf8.parse(keyStr)
    iv = CryptoJS.enc.Utf8.parse(ivStr)
  }

  const srcs = CryptoJS.enc.Utf8.parse(word)
  const encrypted = CryptoJS.AES.encrypt(srcs, key, {
    iv: iv,
    mode: CryptoJS.mode.ECB,
    padding: CryptoJS.pad.Pkcs7
  })
  return CryptoJS.enc.Hex.stringify(encrypted.ciphertext) // 如果是base64的 这里的Hex就换成Base64
}

/**
 * AES解密
 * @param word
 * @param keyStr
 * @param ivStr
 * @returns Hex
 */
export const Decrypt = (word, keyStr, ivStr) => {
  let key = KEY
  let iv = IV

  if (keyStr) {
    key = CryptoJS.enc.Utf8.parse(keyStr)
    iv = CryptoJS.enc.Utf8.parse(ivStr)
  }

  const Hex = CryptoJS.enc.Hex.parse(word) // 如果是base64的 这里的Hex就换成Base64
  const src = CryptoJS.enc.Base64.stringify(Hex)

  const decrypt = CryptoJS.AES.decrypt(src, key, {
    iv: iv,
    mode: CryptoJS.mode.ECB,
    padding: CryptoJS.pad.Pkcs7
  })

  const decryptedStr = decrypt.toString(CryptoJS.enc.Utf8)
  return decryptedStr.toString()
}