前言:
在跟一个老系统对接的时候,对方使用了DES加密,来传输某些关键信息,项目中有没有DES加解密工具类,本人之前没有接触过 DES 加解密算法,借此机会简单学习后,封装了工具类,分享给有需要的伙伴。
什么是DES加密?
DES(Data Encryption Standard):DES加密是一种对称加密算法,所谓对称加密就是加密解密使用的都是同一个秘钥,不过DES加密已经可以破解了,建议使用非对称加密算法。
DES加密原理:
DES算法为密码体制中的对称密码体制,需要加密的明文按64位进行分组,加密密钥是根据用户输入的秘钥生成的,密钥长64位,但事实上使用的秘钥是56位及附加的8位奇偶参与DES运算(第8、16、24、32、40、48、56、64位是校验位, 使得每个密钥都有奇数个1,在计算密钥时要忽略这8位),分组后的明文组和56位的密钥按位替代或交换的方法形成密文组的加密方法。
DES加密算法的优缺点?
- 优点:算法简单,易于实现,效率高,系统开销小。
- 缺点:安全系数不是很高,秘钥管理复杂。
Java实现的DES加解密方法如下:
package com.zy.study.utils;
import org.apache.commons.codec.binary.Base64;
import javax.crypto.Cipher;
import javax.crypto.spec.SecretKeySpec;
import java.nio.charset.StandardCharsets;
import java.security.Key;
public class DesUtil{
/**
* 加密数据
* @param encryptString
* @param encryptKey
* @return
* @throws Exception
*/
public static String encryptDES(String encryptString, String encryptKey) throws Exception {
Cipher cipher = Cipher.getInstance("DES/ECB/PKCS5Padding");
cipher.init(Cipher.ENCRYPT_MODE, new SecretKeySpec(getKey(encryptKey), "DES"));
byte[] encryptedData = cipher.doFinal(encryptString.getBytes("UTF-8"));
return Base64.encodeBase64String(encryptedData);
}
/**
* key 不足8位补位
* @param keyRule
*/
public static byte[] getKey(String keyRule) {
Key key = null;
byte[] keyByte = keyRule.getBytes();
// 创建一个空的八位数组,默认情况下为0
byte[] byteTemp = new byte[8];
// 将用户指定的规则转换成八位数组
for (int i = 0; i < byteTemp.length && i < keyByte.length; i++) {
byteTemp[i] = keyByte[i];
}
key = new SecretKeySpec(byteTemp, "DES");
return key.getEncoded();
}
/***
* 解密数据
* @param decryptString
* @param decryptKey
* @return
* @throws Exception
*/
public static String decryptDES(String decryptString, String decryptKey) throws Exception {
byte[] sourceBytes = Base64.decodeBase64(decryptString);
Cipher cipher = Cipher.getInstance("DES/ECB/PKCS5Padding");
cipher.init(Cipher.DECRYPT_MODE, new SecretKeySpec(getKey(decryptKey), "DES"));
byte[] decoded = cipher.doFinal(sourceBytes);
return new String(decoded, StandardCharsets.UTF_8);
}
public static void main(String[] args) throws Exception {
String clearText = "come on 2024";
String key = "00cac4820e6e14ca0d73a5c6c8d031bc";//密钥
System.out.println("明文:"+clearText+"\n密钥:"+key);
String encryptText = encryptDES(clearText, key);
String code = Base64.encodeBase64String(encryptText.getBytes());
System.out.println("加密后:"+code);
String decryptText = decryptDES(new String(Base64.decodeBase64(code)), key);
System.out.println("解密后:"+decryptText);
}
}
加解密运行效果:
明文:come on 2024
密钥:00cac4820e6e14ca0d73a5c6c8d031bc
加密后:U2RmdzBReXRUZzBMczVBQm5INkxpUT09
解密后:come on 2024
如有不正确的地方请各位指出纠正。