BadPaddingExeception同时解密AES256

时间:2018-09-21 11:07:08

标签: java encryption java-me aes

当前在AES哈希解密方面存在问题。

当我使用AES256加密时,我得到以下结果(在base64编码之后)

07sKQfb9dN86XAMxFmVKHQAAAAAAAAAAAAAAAAAAAAA=

我认为我的问题是AAAAAAAA等问题,出于某种原因,我认为无论如何在解密过程中都不会删除填充。

我的代码

public String encrypt(String key, String initVector, String value) throws Exception {
        IvParameterSpec iv = new IvParameterSpec(initVector.getBytes("UTF-8"), 0, initVector.getBytes().length);
        SecretKeySpec skeySpec = new SecretKeySpec(key.getBytes("UTF-8"), 0, key.getBytes().length, "AES");

        Cipher cipher = Cipher.getInstance("AES/CBC/PKCS5PADDING");
        cipher.init(Cipher.ENCRYPT_MODE, skeySpec, iv);

        byte[] encrypted = new byte[32];

        cipher.doFinal(value.getBytes(), 0, value.getBytes().length, encrypted, 0);

        System.out.println("Base64: " + Base64.encode(encrypted));
        System.out.println("Hex: " + bytesToHex(encrypted));

        return Base64.encode(encrypted);
}

public String decrypt(String key, String initVector, String encrypted) {
    try {
        IvParameterSpec iv = new IvParameterSpec(initVector.getBytes("UTF-8"), 0, initVector.getBytes().length);
        SecretKeySpec skeySpec = new SecretKeySpec(key.getBytes("UTF-8"), 0, key.getBytes().length, "AES");

        Cipher cipher = Cipher.getInstance("AES/CBC/PKCS5PADDING");
        cipher.init(Cipher.DECRYPT_MODE, skeySpec, iv);

        byte[] decrypted = new byte[64];
        cipher.doFinal(Base64.decode(encrypted), 0, Base64.decode(encrypted).length, decrypted, 0);

        return new String(decrypted);
    } catch (Exception ex) {
        ex.printStackTrace();
    }

    return null;
}

我对base64 07sKQfb9dN86XAMxFmVKHQ=进行编码时期望什么

我正在加密的字符串:测试 密钥:password12345678password12345678

1 个答案:

答案 0 :(得分:0)

    byte[] decrypted = new byte[64];

您创建了一个64字节的数组,但是解密后的值可能更短(Java不像C那样使用零字符串终止符)。因此,您不应对参数长度进行假设

尝试使用

encrypted = cipher.doFinal(value.getBytes());

decrypted = cipher.doFinal(Base64.decode(encrypted));