CryptoJS自定义加解密
import CryptoJS from 'crypto-js';
const Base64 = require('js-base64').Base64;
const EncryptionKey = 'encryptionKey';
CryptoJS
:这是一个流行的 JavaScript 加密库,用于提供各种加密算法的实现,包括 AES 加密。js-base64
:这是一个提供 Base64 编码和解码功能的库,用于在加密过程中处理数据的编码。
EncryptionKey
是一个用于 AES 加密的密钥。在实际应用中,这个密钥应该更长(通常是 128 比特、192 比特或 256 比特)且更复杂,以提高加密的安全性。
加密函数 encrypt
export const encrypt = word => {
if (word == '' || word === undefined) {
return '';
}
// 对输入的字符串进行 Base64 编码
word = Base64.encode(word);
// 将密钥转换为 Utf8 编码格式
var key = CryptoJS.enc.Utf8.parse(EncryptionKey);
// 将要加密的数据转换为 Utf8 编码格式
var srcs = CryptoJS.enc.Utf8.parse(word);
// 使用 AES 加密算法进行加密,使用 ECB 模式和 Pkcs7 填充方式
var encrypted = CryptoJS.AES.encrypt(srcs, key, {
mode: CryptoJS.mode.ECB,
padding: CryptoJS.pad.Pkcs7
});
// 将加密后的数据转换为 Base64 编码并返回
return Base64.encode(encrypted.toString());
};
encrypt
函数接受一个word
参数,即要加密的字符串。- 首先检查输入是否为空或未定义,如果是则直接返回空字符串。
- 使用
Base64.encode(word)
将输入的字符串进行 Base64 编码,这是为了在 AES 加密前处理数据格式。 CryptoJS.enc.Utf8.parse(EncryptionKey)
将设定的密钥转换为 CryptoJS 可识别的 Utf8 格式。CryptoJS.enc.Utf8.parse(word)
将 Base64 编码后的字符串转换为 Utf8 格式,作为 AES 加密的原始数据。CryptoJS.AES.encrypt
使用 AES 加密算法对srcs
进行加密,使用 ECB 模式和 Pkcs7 填充方式。Base64.encode(encrypted.toString())
将加密后的数据转换为 Base64 编码,并返回加密后的字符串。
解密函数 decrypt
export const decrypt = word => {
if (word == '' || word === undefined) {
return '';
}
// 对输入的字符串进行 Base64 解码
word = Base64.decode(word);
// 将密钥转换为 Utf8 编码格式
var key = CryptoJS.enc.Utf8.parse(EncryptionKey);
// 使用 AES 解密算法进行解密,使用 ECB 模式和 Pkcs7 填充方式
var decrypt = CryptoJS.AES.decrypt(word, key, {
mode: CryptoJS.mode.ECB,
padding: CryptoJS.pad.Pkcs7
});
// 将解密后的数据转换为 Utf8 编码并解析成字符串,然后返回
return CryptoJS.enc.Utf8.stringify(decrypt).toString();
};
decrypt
函数接受一个word
参数,即要解密的字符串。- 同样,首先检查输入是否为空或未定义,如果是则直接返回空字符串。
- 使用
Base64.decode(word)
将输入的字符串进行 Base64 解码,还原为加密前的格式。 CryptoJS.enc.Utf8.parse(EncryptionKey)
将设定的密钥转换为 CryptoJS 可识别的 Utf8 格式。CryptoJS.AES.decrypt
使用 AES 解密算法对 Base64 解码后的数据进行解密,使用 ECB 模式和 Pkcs7 填充方式。CryptoJS.enc.Utf8.stringify(decrypt).toString()
将解密后的 Utf8 格式数据转换为字符串,并返回解密后的明文。
本文由博客一文多发平台 OpenWrite 发布!