下载:
crypto-js.js下载地址 :crypto-js.js
JavaScript 实现方式:
代码如下:
//加载crypto-js.js文件
<script src="js/crypto-js.js"></script>
<script>
//模拟调用
function ceshi(){
//加密处理
encrypt('QWEASDZXC');//明文参数
//解密处理
decrypt("vlgQpBdfVvMplxwOTjxSyQ==");//加密参数
}
//约定密钥(与后端密钥保持一致)
var key = CryptoJS.enc.Utf8.parse("qP2$bG9;vA0^uW0:");// 密钥16位长度字符 内容可自定义
var IV = CryptoJS.enc.Utf8.parse("qP2$bG9;vA0^uW0:");// 密钥偏移量 16位长度字符
/**
* AES对称加密 (CBC模式,需要偏移量)
* @param {Object} params 明文参数
*/
function encrypt(params){
//明文参数
var str = CryptoJS.enc.Utf8.parse(params);
//加密
var encryptedData = CryptoJS.AES.encrypt(str, key, {
iv:IV,
mode: CryptoJS.mode.CBC, //AES加密模式
padding: CryptoJS.pad.Pkcs7 //填充方式
});
console.log("加密前:"+params);//加密前:QWEASDZXC
console.log("加密后:"+encryptedData);//加密后:vlgQpBdfVvMplxwOTjxSyQ==
return CryptoJS.enc.Base64.stringify(encryptedData.ciphertext); //返回base64格式密文
}
/**
* AES对称解密
* @param {Object} params 加密参数
*/
function decrypt(params){
//base64格式密文转换
var base64 = CryptoJS.enc.Base64.parse(params);
var str = CryptoJS.enc.Base64.stringify(base64);
//解密
var decryptedData = CryptoJS.AES.decrypt(str, key, {
iv:IV,
mode: CryptoJS.mode.CBC, //AES加密模式
padding: CryptoJS.pad.Pkcs7 //填充方式
});
console.log("解密前:"+params);//解密前:vlgQpBdfVvMplxwOTjxSyQ==
console.log("解密后:"+CryptoJS.enc.Utf8.stringify(decryptedData).toString());//解密后:QWEASDZXC
return CryptoJS.enc.Utf8.stringify(decryptedData).toString(); //返回明文
}
</script>
加密、解密效果如下:
key 是密钥 ,iv 是密钥偏移量,对称解密使用的算法是 AES-128-CBC算法,数据采用 Pkcs7填充 , 这里的 key 需要为16位,注意约定密钥要与后端协定一致。
java实现方式:
AESUtils工具类
代码如下:
package com.ceshi.util;
import com.sun.org.apache.xml.internal.security.utils.Base64;
import javax.crypto.Cipher;
import javax.crypto.spec.IvParameterSpec;
import javax.crypto.spec.SecretKeySpec;
import java.text.SimpleDateFormat;
import java.util.Date;
/**
* AES加密,key的大小必须是16个字节
* 如果没有指定分组密码模式和填充模式,ECB/PKCS5Padding就是默认值
* 如果没有指定分组密码模式为CBC,必须指定初始向量(iv),初始向量中密钥的长度必须是16个字节
* NoPadding模式,原文的长度必须是16个字节的整倍数
* @author luvJie-7c
* @date 2022/06/09
*/
public class AESUtils {
//获取Cipher对象的算法
private static String transformation = "AES/CBC/PKCS5Padding";
/**
* 加密
* @param input 明文
* @param key 密钥(AES,密钥的长度必须是16个字节)
* @param algorithm 获取密钥的算法
* @return 返回密文
* @throws Exception
*/
public static String encrypt(String input, String key, String algorithm) throws Exception {
// 1,获取Cipher对象
Cipher cipher = Cipher.getInstance(transformation);
// 指定密钥规则
SecretKeySpec sks = new SecretKeySpec(key.getBytes(), algorithm);
// 2.初始化向量的秘钥长度需要根据算法而定,des 8个字节长度 aes 16个字节长度
//这里为了方便,统一使用传来的秘钥
IvParameterSpec iv = new IvParameterSpec(key.getBytes());
cipher.init(Cipher.ENCRYPT_MODE, sks, iv);
// cipher.init(Cipher.ENCRYPT_MODE, sks);
// 3. 加密
byte[] bytes = cipher.doFinal(input.getBytes());
// 对数据进行Base64编码
String encode = Base64.encode(bytes);
return encode;
}
/**
* 解密
* @param input 密文
* @param key 密钥(AES,密钥的长度必须是16个字节)
* @param algorithm 获取密钥的算法
* @return 返回原文
* @throws Exception
*/
public static String decrypt(String input, String key, String algorithm) throws Exception {
Cipher cipher = Cipher.getInstance(transformation);
SecretKeySpec sks = new SecretKeySpec(key.getBytes(), algorithm);
IvParameterSpec iv = new IvParameterSpec(key.getBytes());
cipher.init(Cipher.DECRYPT_MODE, sks, iv);
// cipher.init(Cipher.DECRYPT_MODE, sks);
byte[] bytes = cipher.doFinal(Base64.decode(input));
return new String(bytes);
}
//测试
public static void main(String[] args) {
String params = "QWEASDZXC";
String key = "qP2$bG9;vA0^uW0:"; // 约定的秘钥
String sf = "AES";
System.out.println("加密前字符串:"+params);//QWEASDZXC
try {
//加密
String jiami = encrypt(params,key,sf);
System.out.println("加密后字符串:"+jiami);//vlgQpBdfVvMplxwOTjxSyQ==
//解密
String jiemi = decrypt(jiami,key,sf);
System.out.println("解密后字符串:"+jiemi);//QWEASDZXC
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
加密、解密效果如下:
前端以url传参的方式发送请求注意事项:
加密后的密文带"+"号(如:JWCDBnjx5YFhOpZPYVhWvfMYJZG7OAZI+7gnT0FEHjA=),向后端传入参数,参数中的“+”全部变成了空格,原因是URL中默认的将“+”号转义了。
解决方法:
一、重新自定义明文,加密一个不带加号的密文
二、使用encodeURIComponent(key)函数
后端接收使用示例:
//获取加密key
String key = request.getParameter("key");
//AES加密
String sf = "AES";
//约定秘钥
String ydkey = "qP2$bG9;vA0^uW0:";
if(!"".equals(key) && key != null && !"null".equals(key)){
String jmzfc = AESUtils.decrypt(key,ydkey,sf); // 获得解密后的字符串
//匹配解密后的数据
if("QWEASDZXC".equals(jmzfc)){
......
}
}
vue 实现AES对称加密:
vue 实现AES对称加密(CBC模式)