+
95
-

javax.crypto.BadPaddingException: Given final block not properly padded

今天使用java进行AES加密解密的时候报错

javax.crypto.BadPaddingException: Given final block not properly padded

在windows上正常,到了linux就出错

网友回复

+
15
-

javax.crypto.BadPaddingException: Given final block not properly padded 是一个常见的异常,通常在使用对称加密算法(如 AES、DES)时出现。这个异常通常表示加密或解密过程中的数据填充有问题。下面是一些可能导致这个异常的常见原因及解决方法:

1. 填充方式不匹配

加密和解密时使用的填充方式必须一致。常见的填充方式包括 PKCS5Padding 和 PKCS7Padding。确保你在加密和解密时使用了相同的填充方式。

示例:

String transformation = "AES/CBC/PKCS5Padding";
Cipher cipher = Cipher.getInstance(transformation);
2. 密钥不匹配

加密和解密时使用的密钥必须一致。如果密钥不匹配,也可能导致这个异常。

3. 数据损坏

加密后的数据在传输或存储过程中可能会被损坏,导致解密时出现填充错误。确保数据在传输和存储过程中保持完整性。

4. 初始向量(IV)不匹配

如果你使用的是带有模式的加密算法(如 CBC 模式),加密和解密时使用的初始向量(IV)必须一致。

5. 解密的数据不是有效的填充格式

尝试解密的数据可能不是使用预期的填充方式加密的。例如,你可能尝试解密一个未加密或使用不同算法加密的数据。

示例代码

下面是一个完整的示例,展示了如何正确地使用 AES 加密和解密,确保填充方式、密钥和 IV 一致。

import javax.crypto.Cipher;
import javax.crypto.KeyGenerator;
import javax.crypto.SecretKey;
import javax.crypto.spec.IvParameterSpec;
import java.security.SecureRandom;
import java.util.Base64;

public class AESExample {
    public...

点击查看剩余70%

我知道答案,我要回答