VUE中的 AES加密和解密

Posted jackjo

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了VUE中的 AES加密和解密相关的知识,希望对你有一定的参考价值。

import CryptoJS from crypto-js/crypto-js

// 默认的 KEY 与 iv 如果没有给
const KEY = CryptoJS.enc.Utf8.parse(F697467B14B076F2)
const IV = CryptoJS.enc.Utf8.parse(0102030405060708)

/**
 * AES加密 :字符串 key iv  返回base64
 */
export function Encrypt(word, keyStr, ivStr) {
  let key = KEY
  let iv = IV

  if (keyStr) {
    key = CryptoJS.enc.Utf8.parse(keyStr);
    iv = CryptoJS.enc.Utf8.parse(ivStr);
  }
  let srcs = CryptoJS.enc.Utf8.parse(word);
  let encrypted = CryptoJS.AES.encrypt(srcs, key, {iv: iv, mode: CryptoJS.mode.CBC, padding: CryptoJS.pad.Pkcs7});
  let hexStr = encrypted.ciphertext.toString().toUpperCase();
  return hexStr
}

/**
 * AES 解密 :字符串 key iv  返回base64
 *
 */
export function Decrypt(word, keyStr, ivStr) {
  let key = KEY
  let iv = IV

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

  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();
}





//使用
import { Encrypt, Decrypt } from @/utils/crypto

let name = 123123

// 加密
let encryptName = Encrypt(name)

console.log(encryptName)

// 解密
let encryptName = Decrypt(name)

console.log(encryptName)

 

以上是关于VUE中的 AES加密和解密的主要内容,如果未能解决你的问题,请参考以下文章

Java 中的 AES 128 加密 PHP 中的解密

Vue AES+MD5加密 后台解密

用python实现AES加密解密

iOS 中的 AES256 NSString 加密

DES加密解密与AES加密解密

AES加密和解密Java