文章目录

  • 一、发现问题
  • 二、分析问题
  • 三、解决问题
  • 3.1 方法一:不要用openjdk
  • 3.2 方法二:修改KeyGenerator.init
  • 四、全部源码


一、发现问题

javax.crypto.BadPaddingException: Given final block not properly padded. Such issues can arise if a_badpadding

javax.crypto.BadPaddingException: Given final block not properly padded. Such issues can arise if a bad key is used during decryption.
	at java.base/com.sun.crypto.provider.CipherCore.unpad(CipherCore.java:977)
	at java.base/com.sun.crypto.provider.CipherCore.fillOutputBuffer(CipherCore.java:1058)
	at java.base/com.sun.crypto.provider.CipherCore.doFinal(CipherCore.java:855)
	at java.base/com.sun.crypto.provider.DESCipher.engineDoFinal(DESCipher.java:314)
	at java.base/javax.crypto.Cipher.doFinal(Cipher.java:2207)

二、分析问题

这是一个des解密的代码,在执行cipher.doFinal()的时候报错:BadPaddingException

public static String decrypt(String keyStr,String content){
    try {
        Key key = loadKey(keyStr);
        Cipher cipher = Cipher.getInstance("DES");
        cipher.init(Cipher.DECRYPT_MODE,key);
        byte[] source =Base64.getDecoder().decode(content.getBytes(StandardCharsets.UTF_8));
        return new String(cipher.doFinal(source),StandardCharsets.UTF_8);
    }catch (Exception e){
        e.printStackTrace();
        return null;
    }
}

三、解决问题

  • 这边有两个方法,两个方法都能解决问题,二选一即可。

3.1 方法一:不要用openjdk

javax.crypto.BadPaddingException: Given final block not properly padded. Such issues can arise if a_badpadding_02

3.2 方法二:修改KeyGenerator.init

generator.init(new SecureRandom(keyStr.getBytes(StandardCharsets.UTF_8)));

修改成

SecureRandom secureRandom = SecureRandom.getInstance("SHA1PRNG");
secureRandom.setSeed(keyStr.getBytes());
generator.init(secureRandom);

四、全部源码

private static Key loadKey(String keyStr){
        Key key = null;
        try {
            KeyGenerator generator = KeyGenerator.getInstance("DES");
//            generator.init(new SecureRandom(keyStr.getBytes(StandardCharsets.UTF_8)));

            SecureRandom secureRandom = SecureRandom.getInstance("SHA1PRNG");
            secureRandom.setSeed(keyStr.getBytes());
            generator.init(secureRandom);

            key = generator.generateKey();
        }catch (Exception e){
            e.printStackTrace();
        }
        return key;
    }

    public static String encrypt(String keyStr,String content){
        try {
            Key key = loadKey(keyStr);
            Cipher cipher = Cipher.getInstance("DES");
            cipher.init(Cipher.ENCRYPT_MODE,key);
            byte[] source = cipher.doFinal(content.getBytes(StandardCharsets.UTF_8));
            return new String(Base64.getEncoder().encode(source),StandardCharsets.UTF_8);
        }catch (Exception e){
            e.printStackTrace();
            return null;
        }
    }

    public static String decrypt(String keyStr,String content){
        try {
            Key key = loadKey(keyStr);
            Cipher cipher = Cipher.getInstance("DES");
            cipher.init(Cipher.DECRYPT_MODE,key);
            byte[] source =Base64.getDecoder().decode(content.getBytes(StandardCharsets.UTF_8));
            return new String(cipher.doFinal(source),StandardCharsets.UTF_8);
        }catch (Exception e){
            e.printStackTrace();
            return null;
        }
    }