S
Sascha_
Gast
Hallo!
Ich hab mir grade was geschrieben zum ver- und entschlüsseln von Strings. Leider schmeißt er mir beim entschlüsseln eine Exception und ich weiß nicht, was ich da falsch mache bzw. wie ich das lösen kann.
Wenn ich das jetzt aufrufe über:
Bekomme ich für x sowas raus: [B@a56a7c
Und er schmeißt mir bei decrypt in der Zeile
encryptedBytes = encryptCipher.doFinal(cryptBytes);
die folgende Exception:
javax.crypto.IllegalBlockSizeException: Input length must be multiple of 16 when decrypting with padded cipher
Ich hab nachgeschaut, cryptBytes hat ne Länge von 8.
Weiß jetzt leider nicht, wie ich das Problem lösen kann. Irgendwelche Vorschläge?
Danke schon mal,
Sascha
Ich hab mir grade was geschrieben zum ver- und entschlüsseln von Strings. Leider schmeißt er mir beim entschlüsseln eine Exception und ich weiß nicht, was ich da falsch mache bzw. wie ich das lösen kann.
Code:
public static String encrypt(String plaintext) {
String encryptString="";
try {
byte[] plainTextBytes = plaintext.getBytes("ISO-8859-1");
SecretKeySpec specKey = new SecretKeySpec(KEY, "AES");
Cipher encryptCipher = Cipher.getInstance("AES/ECB/PKCS5Padding");
encryptCipher.init(Cipher.ENCRYPT_MODE, specKey);
byte[] encryptedBytes = null;
encryptedBytes = encryptCipher.doFinal(plainTextBytes);
encryptString = encryptedBytes.toString();
}
catch(Exception ex) {
System.out.println(ex);
}
return encryptString;
}
public static String decrypt(String crypttext) {
String plaintext = "";
try {
byte[] cryptBytes = crypttext.getBytes("ISO-8859-1");
SecretKeySpec specKey = new SecretKeySpec(KEY, "AES");
Cipher encryptCipher = Cipher.getInstance("AES/ECB/PKCS5Padding");
encryptCipher.init(Cipher.DECRYPT_MODE, specKey);
byte[] encryptedBytes = null;
encryptedBytes = encryptCipher.doFinal(cryptBytes);
plaintext = encryptedBytes.toString();
}
catch (Exception ex) {
System.out.println(ex);
}
return plaintext;
}
Wenn ich das jetzt aufrufe über:
Code:
String x = Crypt.encrypt("Mein Text");
String y = Crypt.decrypt(x);
Bekomme ich für x sowas raus: [B@a56a7c
Und er schmeißt mir bei decrypt in der Zeile
encryptedBytes = encryptCipher.doFinal(cryptBytes);
die folgende Exception:
javax.crypto.IllegalBlockSizeException: Input length must be multiple of 16 when decrypting with padded cipher
Ich hab nachgeschaut, cryptBytes hat ne Länge von 8.
Weiß jetzt leider nicht, wie ich das Problem lösen kann. Irgendwelche Vorschläge?
Danke schon mal,
Sascha