AES加密

1、带有符号的

import CryptoJS from 'crypto-js';

const key = ''; //密钥必须是16的倍数   前后端保持一致
// 偏移量 16位
const iv = ''; 偏移量字符串必须是16位 当模式是CBC的时候必须设置偏移量    前后端保持一致

export function encrypt(data) {//加密
  return CryptoJS.AES.encrypt(CryptoJS.enc.Utf8.parse(data), CryptoJS.enc.Utf8.parse(key), {
    iv: CryptoJS.enc.Utf8.parse(iv),
    mode: CryptoJS.mode.ECB,
    padding: CryptoJS.pad.Pkcs7,
  }).toString();
}

export function decrypt(data) {//解密
  const decrypted = CryptoJS.AES.decrypt(data, CryptoJS.enc.Utf8.parse(key), {
    mode: CryptoJS.mode.ECB,
    padding: CryptoJS.pad.Pkcs7,
  });

  return decrypted.toString(CryptoJS.enc.Utf8).toString();
}


console.log(encrypt(Fk@1234)) //E/eF6lbTKCmN8sme3erbxA==

2、纯字母数字

import CryptoJS from 'crypto-js';

const key = CryptoJS.enc.Utf8.parse('');
// 偏移量 16位
const iv = CryptoJS.enc.Utf8.parse('');

// 加密
export function encrypt(word) {
  let srcs = CryptoJS.enc.Utf8.parse(word);
  let encrypted = CryptoJS.AES.encrypt(srcs, key, {
    iv: iv,
    mode: CryptoJS.mode.CBC,
    padding: CryptoJS.pad.Pkcs7,
  });

  return encrypted.ciphertext.toString().toUpperCase();
}

// 解密
export function decrypt(word) {
  let encryptedHexStr = CryptoJS.enc.Hex.parse(word);
  let srcs = CryptoJS.enc.Base64.stringify(encryptedHexStr);
  let decrypt = CryptoJS.AES.decrypt(srcs, key, {
    iv: iv,
    mode: CryptoJS.mode.CBC,
    padding: CryptoJS.pad.Pkcs7,
  });
  let decryptedStr = decrypt.toString(CryptoJS.enc.Utf8);

  return decryptedStr.toString();
}


console.log(encrypt(Fk@1234)) //7C49108EDA180460D7A8601AC8E4BA66

你可能感兴趣的:(Js,Vue3.0,前端)