NoPadding填充方式不会对明文块进行填充,就会出现“Input length not multiple of 8 bytes“

DES/ECB/PKCS5Padding和DES/ECB/NoPadding的区别。

DES是一种对称加密算法,它可以使用不同的模式和填充方式进行加密。在Java Cipher API中,提供了四种DES加密模式:ECB、CBC、CFB和OFB。其中,ECB模式是最简单的一种模式,它将明文分成若干个固定大小的块,然后对每个块进行加密。ECB模式的缺点是容易受到重放攻击,因为同样的明文块会得到相同的密文块。

为了解决ECB模式的缺点,可以使用CBC模式。在CBC模式中,每个明文块都需要与前一个密文块进行异或操作,然后再进行加密。这样,即使明文块相同,由于前一个密文块不同,得到的密文块也会不同。CBC模式需要一个初始向量来进行加密,初始向量可以随机生成。CBC模式也需要填充方式来处理不足块的数据。在Java Cipher API中,提供了两种常用的填充方式:PKCS5Padding和NoPadding。

PKCS5Padding是一种常用的填充方式,它会在明文块的末尾添加若干个字节,使得明文块的长度等于加密块的长度。每个填充字节的值等于需要填充的字节数。例如,如果明文块的长度为7,需要填充1个字节,填充字节的值为0x01。如果明文块的长度为6,需要填充2个字节,填充字节的值为0x02 0x02。

相比之下,NoPadding填充方式不会对明文块进行填充。如果明文块的长度不足加密块的长度,就会出现"Input length not multiple of 8 bytes"的错误。因此,如果使用NoPadding填充方式,明文块的长度必须是加密块长度的倍数。

因此,DES/ECB/PKCS5Padding和DES/ECB/NoPadding的区别在于填充方式。如果使用DES/ECB/PKCS5Padding,明文块的长度可以是任意长度,会自动进行填充。如果使用DES/ECB/NoPadding,明文块的长度必须是加密块长度的倍数,否则会出现错误。在实际使用中,建议使用CBC模式,同时使用PKCS5Padding填充方式。例如,可以使用以下代码对数据进行加密和解密:

import javax.crypto.Cipher;
import javax.crypto.spec.SecretKeySpec;
import java.nio.charset.StandardCharsets;
import java.util.Base64;

public class Main {
    public static void main(String[] args) throws Exception {
        String plaintext = "Hello World";
        String keyString = "12345678";
        byte[] keyData = keyString.getBytes(StandardCharsets.UTF_8);
        SecretKeySpec key = new SecretKeySpec(keyData, "DES");

        // Encrypt
        Cipher cipher = Cipher.getInstance("DES/CBC/PKCS5Padding");
        byte[] iv = new byte[8];
        cipher.init(Cipher.ENCRYPT_MODE, key, new javax.crypto.spec.IvParameterSpec(iv));
        byte[] ciphertext = cipher.doFinal(plaintext.getBytes(StandardCharsets.UTF_8));
        String encodedCiphertext = Base64.getEncoder().encodeToString(ciphertext);
        System.out.println("Encrypted: " + encodedCiphertext);

        // Decrypt
        cipher.init(Cipher.DECRYPT_MODE, key, new javax.crypto.spec.IvParameterSpec(iv));
        byte[] decodedCiphertext = Base64.getDecoder().decode(encodedCiphertext);
        byte[] decrypted = cipher.doFinal(decodedCiphertext);
        System.out.println("Decrypted: " + new String(decrypted, StandardCharsets.UTF_8));
    }
}

在上述代码中,我们使用DES/CBC/PKCS5Padding模式对数据进行加密和解密。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值