介绍
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.en