解密IllegalBlockSizeException

时间:2013-03-15 16:14:23

标签: java encryption

以下代码基于加密。 在我的构造函数中,我初始化了这个:

try{
        //To generate the secret key
        KeyGenerator keyGen = KeyGenerator.getInstance("DES");
        sKey = keyGen.generateKey();
        //Initialize the cipher instance to use DES algorithm, ECB mode,
        //and PKCS#5 padding scheme.
        cipherObj = Cipher.getInstance("DES/ECB/PKCS5Padding");
    }
    catch(NoSuchAlgorithmException nsae){nsae.printStackTrace();

    }
    catch(NoSuchPaddingException nspe){nspe.printStackTrace();}

我在名为Encrypt的按钮下有这个代码,它实际上正在工作

try{
    //Initialize the cipher with secret key to encrypt the data.
    cipherObj.init(Cipher.ENCRYPT_MODE, sKey);
    //Read the data into byte array
    byte[] textToEncrypt = txtTobeEncrypted.getText().getBytes();
    //To encrypt the data
    byte[] encryptedData = cipherObj.doFinal(textToEncrypt);
    //Display the encrypted data
    String encryptedText = new String(encryptedData);
    txtEncryptOutput.setText(encryptedText);
}
catch(InvalidKeyException ivkey){ivkey.printStackTrace();}
catch(BadPaddingException bpe){bpe.printStackTrace();}
catch(IllegalBlockSizeException ilbs){ilbs.printStackTrace();}

但是以下代码在Decrypt按钮下无法正常工作

try{
    //Initialize the cipher with secret key to encrypt the data.
    cipherObj.init(Cipher.DECRYPT_MODE, sKey);
    //Read the data into byte array
    byte[] textToDecrypt = txtEncryptOutput.getText().getBytes();
    //To decrypt the data
    byte[] plainData = cipherObj.doFinal(textToDecrypt);
    //Display the encrypted data
    String thePlainText = new String(plainData);
    txtDecrypt.setText(thePlainText);
}
catch(InvalidKeyException ivkey){ivkey.printStackTrace();}
catch(BadPaddingException bpe){bpe.printStackTrace();}
catch(IllegalBlockSizeException ilbs){ilbs.printStackTrace();}

我得到的例外情况如下:

javax.crypto.IllegalBlockSizeException: Input length must be multiple of 8 when decrypting with padded cipher
at com.sun.crypto.provider.CipherCore.doFinal(CipherCore.java:750)
at com.sun.crypto.provider.CipherCore.doFinal(CipherCore.java:676)
at com.sun.crypto.provider.DESCipher.engineDoFinal(DESCipher.java:314)
at javax.crypto.Cipher.doFinal(Cipher.java:2086)
at cryptography.FileEncryption.cmdDecryptActionPerformed(FileEncryption.java:209)

所以请任何人解释为什么我会得到这个例外?

2 个答案:

答案 0 :(得分:2)

您无法将随机字节序列解码为String。大多数字符编码不会将每个字节或字节序列映射到字符;这些将用 (替换字符)替换信息。

相反,使用合适的编码(如Base-64)将密文转换为可打印的字符串并再次返回。

答案 1 :(得分:0)

您可能会收到此异常,因为txtEncryptOutput.getText().getBytes()的长度不是8的倍数。

您可以通过在调试器下检查它,或将长度输出到您的记录系统终端来确认。