【node】node中AES加解密

159 阅读1分钟

【node】node中AES加解密

采用AES加密方式
 加密模式采用CBC模式, 填充采用pkcs7padding, 数据块用128位, 密码AES_KEY (可以自己定义) 偏移量IV PROCESS_ENV.AES_IV (可以自己定义)

/**
 * 加密用户ID
 *
 * @param k 密钥
 * @param i 初始化向量
 * @param text 待加密的文本或WordArray对象
 * @returns 加密后的Base64字符串
 */
export function encryptUserId(text: string | CryptoJS.lib.WordArray) {
  const key = CryptoJS.enc.Utf8.parse(PROCESS_ENV.AES_KEY)
  const iv = CryptoJS.enc.Utf8.parse(PROCESS_ENV.AES_IV)
  const encrypted = CryptoJS.AES.encrypt(text, key, {
    iv,
    mode: CryptoJS.mode.CBC,
    padding: CryptoJS.pad.Pkcs7,
  })
  return encrypted.ciphertext.toString(CryptoJS.enc.Base64)
}

/**
 * 解密用户ID
 *
 * @param k 密钥,使用UTF-8编码
 * @param i 初始化向量,使用UTF-8编码
 * @param base64 待解密的密文,可以是Base64字符串或CipherParams对象
 * @returns 解密后的用户ID字符串
 */
export function decryptUserId(base64: string | CryptoJS.lib.CipherParams) {
  const key = CryptoJS.enc.Utf8.parse(PROCESS_ENV.AES_KEY)
  const iv = CryptoJS.enc.Utf8.parse(PROCESS_ENV.AES_IV)
  const encrypted = CryptoJS.AES.decrypt(base64, key, {
    iv,
    mode: CryptoJS.mode.CBC,
    padding: CryptoJS.pad.Pkcs7,
  })
  return encrypted.toString(CryptoJS.enc.Utf8)
}