Java AES加密:给定的最后一个块未正确填充

Java AES加密:给定的最后一个块未正确填充,java,encryption,text,aes,Java,Encryption,Text,Aes,我在Java中尝试使用AES加密时遇到此错误。我使用128位的密钥。我的目标是加密某些数据,这些数据稍后将插入数据库 我是加密新手,所以任何帮助都是有用的 下面是代码的外观: public class AES2 { private static final String algo = "AES/CBC/PKCS5Padding"; private static final byte[] keyValue = new byte[] { 'T', 'h', 'e',

我在Java中尝试使用AES加密时遇到此错误。我使用128位的密钥。我的目标是加密某些数据,这些数据稍后将插入数据库

我是加密新手,所以任何帮助都是有用的

下面是代码的外观:

public class AES2 {
    private static final String algo = "AES/CBC/PKCS5Padding";
    private static final byte[] keyValue = 
        new byte[] { 'T', 'h', 'e', 'B', 'e', 's', 't','S', 'e', 'c', 'r','e', 't', 'K', 'e', 'y' };

    public static String encrypt(String Data) throws Exception {

        //KeyGenerator KeyGen = KeyGenerator.getInstance("AES");
        //KeyGen.init(128);

        //SecretKey SecKey = KeyGen.generateKey();
        Key key=generateKey();

        //generar IV
        byte[] iv = new byte[16];
        SecureRandom random = new SecureRandom();
        random.nextBytes(iv);
        IvParameterSpec ivParameterSpec = new IvParameterSpec(iv);

        //cifrar
        Cipher c = Cipher.getInstance(algo);
        c.init(Cipher.ENCRYPT_MODE, key, ivParameterSpec);

        byte[] encVal = c.doFinal(Data.getBytes());
        String encryptedValue = new BASE64Encoder().encode(encVal);
        return encryptedValue;
    }

    public static String decrypt(String encryptedData) throws Exception {
        Key key = generateKey();

        byte[] iv = new byte[16];
        SecureRandom random = new SecureRandom();
        random.nextBytes(iv);
        IvParameterSpec ivParameterSpec = new IvParameterSpec(iv);

        Cipher c = Cipher.getInstance(algo);
        c.init(Cipher.DECRYPT_MODE, key,ivParameterSpec);

        byte[] decordedValue = new BASE64Decoder().decodeBuffer(encryptedData);
        byte[] decValue = c.doFinal(decordedValue);
        String decryptedValue = new String(decValue);
        return decryptedValue;
    }

    private static Key generateKey() throws Exception {
        Key key = new SecretKeySpec(keyValue, "AES");
        return key;
}
}

Main class:

public class aesMain {

    /**
     * @param args the command line arguments
     */
    public static void main(String[] args) throws Exception {

        String texto = "hola mama";
        String encryptedText=AES2.encrypt(texto);
        String decryptedText=AES2.decrypt(encryptedText);


        System.out.println("Plain text : " + texto);
        System.out.println("Encrypted Text : " + encryptedText);
        System.out.println("Decrypted Text : " + decryptedText);
    }

}

填充错误通常不是填充中的错误,而是解密过程中的错误密钥或IV。删除填充之前的明文将产生随机字节,然后可能会报告为错误填充

在这种情况下,使用不同的IV进行加密和解密。但是,在加密和解密期间,IV必须相同。一个常见的过程是在加密过程中创建一个随机IV,并将其作为密文的前缀。在解密之前,检索IV并将其从密文中剥离


请参阅以了解错误的IV将如何影响解密。

不是密码专家,但非常确定您需要使用与加密相同的IV进行解密。虽然我不是一个“秘密”,所以有些人只是在加密数据前加上它(然后在解密前将其拔出。谢谢,现在我使用相同的iv进行加密和解密,并且我没有收到任何错误,现在我不想知道输出是否正确。是否有在线aes加密机我可以使用?我使用,但你需要手动通过填充。