AES 加解密(包含JS、VUE、JAVA、MySQL)工具方法

介绍

AES 是 Advanced Encryption Standard 的缩写,是最常见的对称加密算法。AES 在密码学中又称 Rijndael 加密法,是美国联邦政府采用的一种区块加密标准。这个标准用来替代原先的 DES,已经被多方分析且广为全世界所使用。

基本原理:AES 的加密公式为 C=E(K,P),其中 K 为密钥,P 为明文,C 为密文。

加密流程图:
在这里插入图片描述

封装工具方法

JS 工具方法

// 引入依赖
<script src="https://cdnjs.cloudflare.com/ajax/libs/crypto-js/4.0.0/crypto-js.min.js"></script>

// 加密方法
function encrypt(content, key) {
   
   
    return CryptoJS.AES.encrypt(content, CryptoJS.enc.Utf8.parse(key), {
   
   
        mode: CryptoJS.mode.ECB,
        padding: CryptoJS.pad.Pkcs7
    }).ciphertext.toString();
}

// 解密方法
function decrypt(content, key) {
   
   
    return CryptoJS.AES.decrypt(CryptoJS.enc.Base64.stringify(CryptoJS.enc.Hex.parse(content)), CryptoJS.enc.Utf8.parse(key), {
   
   
        mode: CryptoJS.mode.ECB,
        padding: CryptoJS.pad.Pkcs7
    }).toString(CryptoJS.enc.Utf8);
}

例子:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8" />
    <script src="https://cdnjs.cloudflare.com/ajax/libs/crypto-js/4.0.0/crypto-js.min.js"></script>
    <script>
        var key = "xxxxxxxxxxxxxxxx";
        function encryptText() {
     
     
            var plain = document.getElementById("plain").value;
            var encrypted = encrypt(plain, key);
            document.getElementById("encrypted").value = encrypted;
        }

        function decryptText() {
     
     
            var encrypted = document.getElementById("todecrypt").value;
            var decrypted = decrypt(encrypted, key);
            document.getElementById("decrypted").value = decrypted;
        }

        // 加密方法
        function encrypt(content, key) {
     
     
            return CryptoJS.AES.
Vue.jsJava 中的 AES 加密解密通常涉及使用相同的加密算法,AES (Advanced Encryption Standard) 是一种广泛使用的对称加密标准。以下是基本步骤: 1. **Vue 中加密**: - 首先,安装 Vue 的加密库,如 `vue-aes-js` 或者 `crypto-js`。 - 在 Vue 组件中,你可以创建一个工具函数,比如这样: ```javascript import Aes from 'crypto-js/aes'; export function encrypt(data, key) { const iv = CryptoJS.lib.WordArray.random(16); // 生成随机IV let encrypted = Aes.encrypt(JSON.stringify(data), key, { mode: CryptoJS.mode.CBC, iv: iv }); return { ciphertext: encrypted.toString(CryptoJS.enc.Base64), iv: iv.toString(CryptoJS.enc.Hex) }; } ``` - 加密时将数据转换为 JSON 字符串,并使用给定的密钥加密。 2. **Java 解密**: - 使用同款加密库,如 `javax.crypto.Cipher` 或 `org.bouncycastle.jce.provider.BouncyCastleProvider`。 - 创建一个对应的解密函数: ```java import javax.crypto.Cipher; import org.bouncycastle.jce.provider.BouncyCastleProvider; public static String decrypt(String ciphertext, String iv, String key) throws Exception { BouncyCastleProvider bcprov = new BouncyCastleProvider(); Security.addProvider(bcprov); Cipher cipher = Cipher.getInstance("AES/CBC/PKCS5Padding", "BC"); byte[] decodedIv = Base64.decode(iv, Base64.DEFAULT); cipher.init(Cipher.DECRYPT_MODE, SecretKeySpec(key.getBytes(), "AES"), IvParameterSpec(decodedIv)); byte[] decryptedBytes = cipher.doFinal(Base64.decode(ciphertext, Base64.DEFAULT)); return new String(decryptedBytes, StandardCharsets.UTF_8); } ``` - 将接收到的 Base64 编码的密文和 IV 进行解密,得到原始的数据。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值