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,ключ);
document.getElementById("расшифровано").value = расшифровано;
}
// шифрованиеметод функция шифрования (содержимое, 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);
}
</script>
</head>
<body>
<h2>добавлять Расшифроватьтест</h2>
<div style="padding: 1rem 0">
<input id="plain" type="text" />
<button type="button" onclick="encryptText()">шифрование</button>
<input id="encrypted" type="text"/>
</div>
<div>
<input id="todecrypt" type="text"/>
<button type="button" onclick="decryptText()">Расшифровать</button>
<input id="decrypted" type="text"/>
</div>
</body>
</html>
Методы инструмента VUE
// Добавить зависимости
npm install crypto-js
// шифрованиеметодfunction onEncrypt(content: any, key: any) {
return CryptoJS.AES.encrypt(content, CryptoJS.enc.Utf8.parse(key), {
mode: CryptoJS.mode.ECB,
padding: CryptoJS.pad.Pkcs7,
}).ciphertext.toString().toUpperCase();
}
// Метод расшифровки
function onDecrypt(content: any, key: any) {
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);
}
пример:
<script setup lang="ts">
import { onMounted, reactive, toRefs } from "vue";
import CryptoJS from "crypto-js";
const state = reactive({
key: "xxxxxxxxxxxxxxxx",
plain: null,
encrypted: null,
todecrypt: null,
decrypted: null
})
const {key,plain,encrypted,todecrypt,decrypted} = toRefs(state)
function encryptText() {
state.encrypted = onEncrypt(state.plain, state.key);
}
function decryptText() {
state.decrypted = onDecrypt(state.todecrypt,state.key);
}
// шифрованиеметодfunction onEncrypt(content: any, key: any) {
return CryptoJS.AES.encrypt(content, CryptoJS.enc.Utf8.parse(key), {
mode: CryptoJS.mode.ECB,
padding: CryptoJS.pad.Pkcs7,
}).ciphertext.toString().toUpperCase();
}
// Метод расшифровки
function onDecrypt(content: any, key: any) {
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);
}
</script>
<template>
<div class="aes">
<h1>AESдобавлять Расшифровать</h1>
<el-row :gutter="20" style="padding: 1rem 0">
<el-col :span="6"><el-input v-model="plain" placeholder="Пожалуйста, введите содержание"></el-input></el-col>
<el-col :span="2"><el-button type="primary" @click="encryptText()">шифрование</el-button></el-col>
<el-col :span="12"><div>{{state.encrypted}}</div></el-col>
</el-row>
<el-row :gutter="20">
<el-col :span="6"><el-input v-model="todecrypt" placeholder="Пожалуйста, введите содержание"></el-input></el-col>
<el-col :span="2"><el-button type="primary" @click="decryptText()">Расшифровать</el-button></el-col>
<el-col :span="12"><div>{{state.decrypted}}</div></el-col>
</el-row>
</div>
</template>
<style lang="scss" scoped>
.aes {
text-align: center;
}
</style>
JAVA-инструменты
package com.tansci.util;
import org.apache.commons.codec.binary.Hex;
import javax.crypto.Cipher;
import javax.crypto.KeyGenerator;
import javax.crypto.spec.SecretKeySpec;
/**
* @ClassName: AESUtil.java
* @ClassPath: com.tansci.util.AESUtil.java
* @Description: Симметричное шифрование и дешифрование AESИнструменты
* @Author: tanyp
* @Date: 2024/4/18 12:00
**/
public class AESUtil {
/**
* @MonthName: encrypt
* @Description: шифрование
* @Author: tanyp
* @Date: 2024/4/18 12:00
* @Param: [content, key: 16 бит]
* @return: java.lang.String
**/
public static String encrypt(String content, String key) throws Exception {
KeyGenerator kgen = KeyGenerator.getInstance("AES");
kgen.init(128);
Cipher cipher = Cipher.getInstance("AES/ECB/PKCS5Padding");
cipher.init(Cipher.ENCRYPT_MODE, new SecretKeySpec(key.getBytes(), "AES"));
byte[] b = cipher.doFinal(content.getBytes("utf-8"));
return Hex.encodeHexString(b);
}
/**
* @MonthName: decrypt
* @Description: Расшифровать
* @Author: tanyp
* @Date: 2024/4/18 12:00
* @Param: [encryptStr, key:16 бит]
* @return: java.lang.String
**/
public static String decrypt(String encryptStr, String key) throws Exception {
KeyGenerator kgen = KeyGenerator.getInstance("AES");
kgen.init(128);
Cipher cipher = Cipher.getInstance("AES/ECB/PKCS5Padding");
cipher.init(Cipher.DECRYPT_MODE, new SecretKeySpec(key.getBytes(), "AES"));
byte[] encrypttBytes = Hex.decodeHex(encryptStr);
byte[] decryptBytes = cipher.doFinal(encrypttBytes);
return new String(decryptBytes);
}
}
Использование MySQL
-- шифрование
select HEX(AES_ENCRYPT('admin','xxxxxxxxxxxxxxxx'))
-- Расшифровать
select CONVERT(AES_DECRYPT(UNHEX('305e188e6818582f8298551e4b50702a'),'xxxxxxxxxxxxxxxx') USING UTF8MB4)
select AES_DECRYPT(UNHEX('4C80D7BE4719ED572565378025E7AC85'),'xxxxxxxxxxxxxxxx')