Java使用DES加密解密

一、DES算法

DES(Data Encryption Standard):数据加密标准,它是由IBM公司研制的一种对称密码算法

DES是一个分组加密算法,典型的DES以64位分组对数据加密,加密和解密用的是用一个算法。

总长度64位8字节,其中8位作为校验码,不参与加密算法。

二、秘钥与加密算法

秘钥是一种参数(它是在明文转换为密文或将密文转换为明文的算法中输入的数据)

加密算法是明文转换为密文的变换函数,同样的秘钥可以用不同的加密算法,得到的密文就不一样

比如凯撒密码,就是将字母循环后移n位,这个n就是一个秘钥,循环后移的方法叫做算法

三、DES加密流程

四、DES加密与解密

提供原始秘钥:长度64位,8字节

    @Test
    public void testDES() throws Exception {
        // 明文
        String plainText = "abcd";
        System.out.println("明文:" + plainText);

        // 提供原始秘钥:长度64位,8字节
        String originKey = "12345678";
        // 根据给定的字节数组构建一个秘钥
        SecretKeySpec key = new SecretKeySpec(originKey.getBytes(), "DES");

        // 加密
        // 1.获取加密算法工具类
        Cipher cipher = Cipher.getInstance("DES");
        // 2.对工具类对象进行初始化,
        // mode:加密/解密模式
        // key:对原始秘钥处理之后的秘钥
        cipher.init(Cipher.ENCRYPT_MODE, key);
        // 3.用加密工具类对象对明文进行加密
        byte[] encipherByte = cipher.doFinal(plainText.getBytes());
        // 防止乱码,使用Base64编码
        String encode = Base64.encodeBase64String(encipherByte);
        System.out.println("加密:" + encode);

        // 解密
        // 2.对工具类对象进行初始化
        cipher.init(Cipher.DECRYPT_MODE, key);
        // 3.用加密工具类对象对密文进行解密
        byte[] decode = Base64.decodeBase64(encode);
        byte[] decipherByte = cipher.doFinal(decode);
        String decipherText = new String(decipherByte);
        System.out.println("解密:" + decipherText);
    }

结果:

 

  • 10
    点赞
  • 37
    收藏
    觉得还不错? 一键收藏
  • 7
    评论
以下是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)); } ```

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值