以下代码基于加密。 在我的构造函数中,我初始化了这个:
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)
所以请任何人解释为什么我会得到这个例外?
答案 0 :(得分:2)
您无法将随机字节序列解码为String
。大多数字符编码不会将每个字节或字节序列映射到字符;这些将用 (替换字符)替换信息。
相反,使用合适的编码(如Base-64)将密文转换为可打印的字符串并再次返回。
答案 1 :(得分:0)
您可能会收到此异常,因为txtEncryptOutput.getText().getBytes()
的长度不是8的倍数。
您可以通过在调试器下检查它,或将长度输出到您的记录系统终端来确认。