用java实现DES解密

DES解密是加密的逆过程。对于DES加密过程可以用以下数学公式来描述:
在这里插入图片描述
其中,Li和Ri是当前进行加密操作的明文的左32位和右32位,而Li-1和Ri-1是前一次进行操作的明文的左32位和右32位。Ki是64位密钥经过算法产生的子密钥。而解密过程可以用如下数学公式来描述:
在这里插入图片描述
由此可以看出,DES的解密操作是加密操作的反向逆过程。对于第二个公式可以做如下推导:
在这里插入图片描述
上述最后一行式子经过化简发现等式左边等于右边,显然上述公式成立。学过数字电子技术的同学应该对上述公式推导的计算方法并不陌生。
以下是通过java实现的DES解码操作:

import com.sun.org.apache.xerces.internal.impl.dv.util.Base64;
import javax.crypto.*;
import javax.crypto.spec.SecretKeySpec;
import java.security.InvalidKeyException;
import java.security.Key;
import java.security.NoSuchAlgorithmException;
import java.util.Scanner;

public class DESDemo {
    public static void main(String[] args) throws Exception
    {
        System.out.println("请输入明文:");
        Scanner in=new Scanner(System.in);
        String clearText=in.nextLine();
        System.out.println("请输入密钥:");
        Scanner in1=new Scanner(System.in);
        String originKey=in1.nextLine();
        String cipherText = desEncript(clearText, originKey);
        System.out.println("通过DES加密后的结果是:");
        System.out.println(cipherText);
        String clearText1=desDecript(cipherText,originKey);
        System.out.println("解密结果是:\n"+clearText1);
    }

    /**
     * 加密算法
     * @param clearText
     * @param originKey
     * @return
     * @throws NoSuchAlgorithmException
     * @throws NoSuchPaddingException
     * @throws InvalidKeyException
     * @throws BadPaddingException
     * @throws IllegalBlockSizeException
     */
    private static String desEncript(String clearText, String originKey) throws NoSuchAlgorithmException, NoSuchPaddingException, InvalidKeyException, BadPaddingException, IllegalBlockSizeException
    {
            Cipher cipher=Cipher.getInstance("DES"); /*提供加密的方式:DES*/
            SecretKeySpec key=getKey(originKey);  /*对密钥进行操作,产生16个48位长的子密钥*/
            cipher.init(Cipher.ENCRYPT_MODE,key); /*初始化cipher,选定模式,这里为加密模式,并同时传入密钥*/
            byte[] doFinal=cipher.doFinal(clearText.getBytes());   /*开始加密操作*/
            String encode= Base64.encode(doFinal);    /*对加密后的数据按照Base64进行编码*/
            return encode;
    }

    /**
     * 解密算法
     * @param cipherText
     * @param originKey
     * @return
     * @throws BadPaddingException
     * @throws IllegalBlockSizeException
     * @throws NoSuchPaddingException
     * @throws NoSuchAlgorithmException
     * @throws InvalidKeyException
     */
    private static String desDecript(String cipherText, String originKey) throws BadPaddingException, IllegalBlockSizeException, NoSuchPaddingException, NoSuchAlgorithmException, InvalidKeyException
    {
        Cipher cipher=Cipher.getInstance("DES");   /*初始化加密方式*/
        Key key=getKey(originKey);  /*获取密钥*/
        cipher.init(Cipher.DECRYPT_MODE,key);  /*初始化操作方式*/
        byte[] decode=Base64.decode(cipherText);  /*按照Base64解码*/
        byte[] doFinal=cipher.doFinal(decode);   /*执行解码操作*/
        return new String(doFinal);   /*转换成相应字符串并返回*/
    }

    /**
     * 获取密钥算法
     * @param originKey
     * @return
     */
    private static SecretKeySpec getKey(String originKey)
    {
            byte[] buffer=new byte[8];
            byte[] originBytes=originKey.getBytes();
            /**
             * 防止输入的密钥长度超过64位
             */
            for(int i=0;i<8&&i<originBytes.length;i++)
            {
                buffer[i]=originBytes[i];  /*如果originBytes不足8,buffer剩余的补零*/
            }
            SecretKeySpec key=new SecretKeySpec(buffer,"DES"); /*第一个参数是密钥字节数组,第二个参数是加密方式*/
            return key;  /*返回操作之后得到的密钥*/
    }
}

程序运行结果如下所示:
在这里插入图片描述

  • 3
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是Java中使用DES算法进行加密和解密的示例代码: ```java import javax.crypto.Cipher; import javax.crypto.SecretKey; import javax.crypto.SecretKeyFactory; import javax.crypto.spec.DESKeySpec; public class DESUtil { public static final String KEY_ALGORITHM = "DES"; public static final String CIPHER_ALGORITHM = "DES/ECB/PKCS5Padding"; /** * DES加密 * @param data 待加密数据 * @param key 密钥 * @return 加密后的数据 * @throws Exception */ public static byte[] encrypt(byte[] data, byte[] key) throws Exception { // 生成一个DESKeySpec对象 DESKeySpec desKeySpec = new DESKeySpec(key); // 创建一个密钥工厂 SecretKeyFactory keyFactory = SecretKeyFactory.getInstance(KEY_ALGORITHM); // 将DESKeySpec对象转换成SecretKey对象 SecretKey secretKey = keyFactory.generateSecret(desKeySpec); // 创建一个密码器 Cipher cipher = Cipher.getInstance(CIPHER_ALGORITHM); // 初始化密码器为加密模式,使用密钥初始化 cipher.init(Cipher.ENCRYPT_MODE, secretKey); // 加密 byte[] result = cipher.doFinal(data); return result; } /** * DES解密 * @param data 待解密数据 * @param key 密钥 * @return 解密后的数据 * @throws Exception */ public static byte[] decrypt(byte[] data, byte[] key) throws Exception { // 生成一个DESKeySpec对象 DESKeySpec desKeySpec = new DESKeySpec(key); // 创建一个密钥工厂 SecretKeyFactory keyFactory = SecretKeyFactory.getInstance(KEY_ALGORITHM); // 将DESKeySpec对象转换成SecretKey对象 SecretKey secretKey = keyFactory.generateSecret(desKeySpec); // 创建一个密码器 Cipher cipher = Cipher.getInstance(CIPHER_ALGORITHM); // 初始化密码器为解密模式,使用密钥初始化 cipher.init(Cipher.DECRYPT_MODE, secretKey); // 解密 byte[] result = cipher.doFinal(data); return result; } } ``` 示例代码中使用了`DES/ECB/PKCS5Padding`算法模式和填充方式,其中: - `DES`是算法名称 - `ECB`是算法模式,ECB模式是最简单的分组模式,每个明文块独立加密 - `PKCS5Padding`是填充方式,将明文数据填充至8字节的整数倍 使用示例: ```java public static void main(String[] args) throws Exception { String data = "Hello, world!"; // 待加密数据 byte[] key = "12345678".getBytes(); // 密钥 byte[] encryptData = DESUtil.encrypt(data.getBytes(), key); System.out.println("加密后的数据:" + new String(encryptData)); byte[] decryptData = DESUtil.decrypt(encryptData, key); System.out.println("解密后的数据:" + new String(decryptData)); } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值