Android加密和解密错误 - javax.crypto.IllegalBlockSizeException:解密时最后一个块不完整

时间:2015-05-07 10:20:43

标签: java android security encryption

我在以下代码中遇到了解密问题。我有一个加密的字符串发送到setData()。我试图解密加密的字符串(数据)。我一直得到的错误是

  

javax.crypto.IllegalBlockSizeException:解密时最后一个块不完整

byte[] data;
String key = "tkg96827pco74510";

byte[] encryptedOut;
String decryptedOut;

Key aesKey;
Cipher cipher;

public void setData(String dataIn){
    this.data = dataIn.getBytes();
    try {
        aesKey = new SecretKeySpec(key.getBytes(), "AES");
        cipher = Cipher.getInstance("AES");

    }catch(Exception e){
        System.out.println("SET DATA ERROR - " + e);
    }
}
public void encrypt() {
    try{
        cipher.init(Cipher.ENCRYPT_MODE, aesKey);
        encryptedOut = cipher.doFinal(data);
    }catch(Exception e){
        System.out.println(e);
    }
}

public void decrypt(){
    try {
        cipher.init(Cipher.DECRYPT_MODE, aesKey);
        decryptedOut = new String(cipher.doFinal(data));

    }catch(Exception e){
        System.out.println("Decrypt Error: " + e);
    }
}

public byte[] getEncrypted() {
   return encryptedOut;
}

public String getDecrypted(){
    return decryptedOut;
}

2 个答案:

答案 0 :(得分:5)

问题是由这一行引起的:

decryptedOut = new String(cipher.doFinal(data));

在这里,您要将原始数据传递给解密。但是你应该在这里通过encryptedOut

所以解决方案是:

decryptedOut = new String(cipher.doFinal(encryptedOut));

是的,请传递一些编码机制将String转换为byteArray,反之亦然,如"UTF-8"

所以正确的行是:

decryptedOut = new String(cipher.doFinal(encryptedOut),"UTF-8");

鉴于你已经完成了像这样的字节转换:

this.data = dataIn.getBytes("UTF-8");

答案 1 :(得分:0)

问题在于:

public String getDecrypted()

在这里:

decryptedOut = new String(cipher.doFinal(data));

String不是二进制数据的容器。在将密文文本放入String.之前,需要以某种方式对密文进行编码。例如,base64-encoding。