前言:
在跟一个老系统对接的时候,对方使用了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