对称加密--Java实现DES加密解密

本文介绍了DES加密的基本概念、工作原理,以及如何在Java中使用ApacheCommonsCodec库实现DES的加解密操作,包括DESUtil工具类的代码示例和实际运行效果。
摘要由CSDN通过智能技术生成

前言:

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

如有不正确的地方请各位指出纠正。

  • 10
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值