AES kann nicht entschlüsselt werden

bennsoncat

Mitglied
Hallo, ich habe mir eine Klasse zusammengebastelt, mit der ich einen Text mit einem 64 Zeichen langen Passwort ver- und entschlüsseln möchte.
Java:
import java.security.Key;
import java.util.Base64;

import javax.crypto.Cipher;
import javax.crypto.spec.SecretKeySpec;

public class SuperStringCrypt {

    private static String k1;
    private static String k2;
    private static String k3;
    private static String k4;

    public static void setKeys(String i1, String i2, String i3, String i4) {
        k1 = i1;
        k2 = i2;
        k3 = i3;
        k4 = i4;
    }

    public static String encrypt(String t) {
        try {
            Cipher c = Cipher.getInstance("AES");
   
            Key key = new SecretKeySpec(k1.getBytes("UTF-8"), "AES");
            c.init(Cipher.ENCRYPT_MODE, key);
            byte[] encVal = c.doFinal(t.getBytes("UTF-8"));
   
            key = new SecretKeySpec(k2.getBytes("UTF-8"), "AES");
            c.init(Cipher.ENCRYPT_MODE, key);
            encVal = c.doFinal(encVal);
   
            key = new SecretKeySpec(k3.getBytes("UTF-8"), "AES");
            c.init(Cipher.ENCRYPT_MODE, key);
            encVal = c.doFinal(encVal);
   
            key = new SecretKeySpec(k4.getBytes("UTF-8"), "AES");
            c.init(Cipher.ENCRYPT_MODE, key);
            encVal = c.doFinal(encVal);
   
            String base64 = Base64.getEncoder().encodeToString(encVal);
            return base64;
        } catch(Exception e) {
            e.printStackTrace();
        }
        return null;
    }

    public static String decrypt(String t) {
        try {
            Cipher c = Cipher.getInstance("AES");
            byte[] decVal = Base64.getDecoder().decode(t);

            Key key = new SecretKeySpec(k1.getBytes("UTF-8"), "AES");
            c.init(Cipher.DECRYPT_MODE, key);
            decVal = c.doFinal(decVal);
   
            key = new SecretKeySpec(k2.getBytes("UTF-8"), "AES");
            c.init(Cipher.DECRYPT_MODE, key);
            decVal = c.doFinal(decVal);
   
            key = new SecretKeySpec(k3.getBytes("UTF-8"), "AES");
            c.init(Cipher.DECRYPT_MODE, key);
            decVal = c.doFinal(decVal);
   
            key = new SecretKeySpec(k4.getBytes("UTF-8"), "AES");
            c.init(Cipher.DECRYPT_MODE, key);
            decVal = c.doFinal(decVal);

            return new String(decVal, "UTF-8");
        } catch(Exception e) {
            e.printStackTrace();
        }
        return null;
    }
}

Hier mal eine Beispiel Klasse zur Anwendung:
Java:
public class Main {

    public static void main(String[] args) {
        SuperStringCrypt.setKeys("=cRHo28Cf6XnGevD", "qzsLUFIgEtNuV937", "J0WKMwlhakimO1A4", "bTQjpdPSYB5rxZy?");

        String encrypted = SuperStringCrypt.encrypt("Hallo Welt");

        System.out.println(encrypted);

        String decrypted = SuperStringCrypt.decrypt(encrypted);

        System.out.println(decrypted);

    }

}

Ich bekomme aber immer bei der Benutzung dieser Klasse das ausgegeben:
Java:
rvNr5/x7i1GlVH2Mf90Vw0T31MqN5kqd0cmi6PlrwyxSaxL43AmL8EQF9Ziw+qjjpfVMVRd8BpsFqmXVCTWoCQ==
javax.crypto.BadPaddingException: Given final block not properly padded
    at com.sun.crypto.provider.CipherCore.doFinal(CipherCore.java:966)
    at com.sun.crypto.provider.CipherCore.doFinal(CipherCore.java:824)
    at com.sun.crypto.provider.AESCipher.engineDoFinal(AESCipher.java:436)
    at javax.crypto.Cipher.doFinal(Cipher.java:2165)
    at SuperStringCrypt.decrypt(SuperStringCrypt.java:57)
    at Main.main(Main.java:11)
null

Die Verschlüsselung funktioniert, aber die Entschlüsselung nicht. Wo ist der Fehler? Könnt ihr mir helfen?
 
Zuletzt bearbeitet:

Tobse

Top Contributor
Hinweis: Diese Strings sind als Schlüssel völlig nutzlos und leicht zu knacken. Benutze den AES PBE Cipher oder PBKDF2
 

bennsoncat

Mitglied
Hinweis: Diese Strings sind als Schlüssel völlig nutzlos und leicht zu knacken. Benutze den AES PBE Cipher oder PBKDF2

Besser?:
Java:
import java.net.URLDecoder;
import java.net.URLEncoder;
import java.security.Key;
import java.security.MessageDigest;
import java.util.Base64;

import javax.crypto.Cipher;
import javax.crypto.spec.SecretKeySpec;

public class SuperStringCrypt {

    private static byte[] k1;
    private static byte[] k2;
    private static byte[] k3;
    private static byte[] k4;

    public static void setKeys(String i1, String i2, String i3, String i4) {
        try {
            MessageDigest md = MessageDigest.getInstance("MD5");
      
            md.update(i1.getBytes("UTF-8"));
            k1 = md.digest();
      
            md.update(i2.getBytes("UTF-8"));
            k2 = md.digest();
      
            md.update(i3.getBytes("UTF-8"));
            k3 = md.digest();
      
            md.update(i4.getBytes("UTF-8"));
            k4 = md.digest();
        } catch (Exception e) {
            k1 = null;
            k2 = null;
            k3 = null;
            k4 = null;
            e.printStackTrace();
        }
  
    }

    public static String encrypt(String t) {
        try {
            Cipher c = Cipher.getInstance("AES");
      
            Key key = new SecretKeySpec(k1, "AES");
            c.init(Cipher.ENCRYPT_MODE, key);
            byte[] encVal = c.doFinal(t.getBytes("UTF-8"));
      
            key = new SecretKeySpec(k2, "AES");
            c.init(Cipher.ENCRYPT_MODE, key);
            encVal = c.doFinal(encVal);
      
            key = new SecretKeySpec(k3, "AES");
            c.init(Cipher.ENCRYPT_MODE, key);
            encVal = c.doFinal(encVal);
      
            key = new SecretKeySpec(k4, "AES");
            c.init(Cipher.ENCRYPT_MODE, key);
            encVal = c.doFinal(encVal);
      
            String base64 = Base64.getEncoder().encodeToString(encVal);
            return URLEncoder.encode(base64, "UTF-8");
        } catch(Exception e) {
            e.printStackTrace();
        }
        return null;
    }

    public static String decrypt(String t) {
        try {
            t = URLDecoder.decode(t, "UTF-8");
            Cipher c = Cipher.getInstance("AES");
            byte[] decodedValue = Base64.getDecoder().decode(t);

            Key key = new SecretKeySpec(k4, "AES");
            c.init(Cipher.DECRYPT_MODE, key);
            decodedValue = c.doFinal(decodedValue);
      
            key = new SecretKeySpec(k3, "AES");
            c.init(Cipher.DECRYPT_MODE, key);
            decodedValue = c.doFinal(decodedValue);
      
            key = new SecretKeySpec(k2, "AES");
            c.init(Cipher.DECRYPT_MODE, key);
            decodedValue = c.doFinal(decodedValue);
      
            key = new SecretKeySpec(k1, "AES");
            c.init(Cipher.DECRYPT_MODE, key);
            decodedValue = c.doFinal(decodedValue);
      
            return new String(decodedValue, "UTF-8");
        } catch(Exception e) {
            e.printStackTrace();
        }
        return null;
    }
}
Wenn nicht, poste mal deine Version der Klasse. Ja, ich weiß, das ist jetzt nicht optimal, aber ich möchte ohne Salz verschlüsseln. Aber, ist das sicherer als vorher und reichte das?

EDIT: Hier noch eine Version:
Java:
import java.net.URLDecoder;
import java.net.URLEncoder;
import java.security.Key;
import java.security.MessageDigest;
import java.util.Base64;

import javax.crypto.Cipher;
import javax.crypto.spec.SecretKeySpec;

public class SuperStringCrypt {

    private static byte[] keyBytes;

    public static void setKey(String k) {
        try {
            MessageDigest md = MessageDigest.getInstance("MD5");
            md.update(k.getBytes("UTF-8"));
            keyBytes = md.digest();
        } catch (Exception e) {
            keyBytes = null;
            e.printStackTrace();
        }
    
    }

    public static String encrypt(String t) {
        try {
            Cipher c = Cipher.getInstance("AES");
        
            Key key = new SecretKeySpec(keyBytes, "AES");
            c.init(Cipher.ENCRYPT_MODE, key);
            byte[] encVal = c.doFinal(t.getBytes("UTF-8"));
        
            String base64 = Base64.getEncoder().encodeToString(encVal);
            return URLEncoder.encode(base64, "UTF-8");
        } catch(Exception e) {
            e.printStackTrace();
        }
        return null;
    }

    public static String decrypt(String t) {
        try {
            t = URLDecoder.decode(t, "UTF-8");
            Cipher c = Cipher.getInstance("AES");
            byte[] decodedValue = Base64.getDecoder().decode(t);

            Key key = new SecretKeySpec(keyBytes, "AES");
            c.init(Cipher.DECRYPT_MODE, key);
            decodedValue = c.doFinal(decodedValue);
        
            return new String(decodedValue, "UTF-8");
        } catch(Exception e) {
            e.printStackTrace();
        }
        return null;
    }
}

Ist das bei einem 62 oder 64 stelligen Password sicher genug? Hab gelesen das mit MD5 mehrere Passwörter den selben Hash haben können.

EDIT:
Ich habe mir natürlich auch sowas angeguckt, bin aber nicht zufrieden damit, da nicht der ganze Hash genommen wird (unsicher?):
Java:
byte[] key = (SALT2 + username + password).getBytes("UTF-8");
MessageDigest sha = MessageDigest.getInstance("SHA-1");
key = sha.digest(key);
key = Arrays.copyOf(key, 16); // use only first 128 bit

SecretKeySpec secretKeySpec = new SecretKeySpec(key, "AES");

--------
Was ist denn jetzt die beste Möglichkeit, um einen Text mit einem 62 oder 64 stelligen Passwort zu verschlüsseln?
 
Zuletzt bearbeitet:

Tobse

Top Contributor
Ich sehe, du verstehst nichts von Verschlüsselung. Ist nicht böse gemeint, aber Verschlüsselung ist eine äußerst sensible Angelegenheit. Wenn man nicht 100% weiss, was man tut, ist das Ergebnis ganz schnell unsicher.

Bzgl. MD5 und den Passwörtern: Passwörter sind selten als Kryptographische Schlüssel zu verwenden (aufgrund der Länge und der geringen Variation der einzelnen Bytes). Um aus einem Passwort einen Kryptographisch nutzbaren Schlüssel zu machen benutzt man eine sogenannte Key-Derivation-Function: Sie nimmt ein Passwort und ein Salt und wandelt es deterministisch (also immer mit dem selben Ergebnis) in einen Kryptographischen Schlüssel um. MD5 kann man zwar als KDF betrachten; praktisch erhöht es aber die Sicherheit nicht, weil es viel zu wenig Rechenleistung benötigt.
Es gibt vordefinierte Verfahren für KDFs, darunte rauch PBKDF2 (Password Based Key Derivation Function Version 2); PBKDF2 baut immer auf einem Hash-Algorithmus (so auch MD5) auf; PBKDF2-SHA256 ist aber deutlich sicherer als PBKDF2-MD5 (weil SHA256 sicherer ist als MD5, diverse Quellen darüber siehe Google).
Ergo: schiebe dein Passwort durch PBKDF2 (dann muss es auch nichtmehr genau 64 Zeichen lang sein) und verschlüssele damit. Für eine sichere Verschlüsselung braucht es aber noch einen guten IV, guten Cipher Mode of Operation und ein brauchbares Padding. Cipher.getInstance("AES") (was identisch ist mit Cipher.getInstance("AES/ECB/NoPadding")) taugt dafür nicht. Recherchiere einfach mal noch ein bisschen, da gibts viele Infos im Netz.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
D Compiler-Fehler Compilierung in VM nicht erfolgreich Allgemeine Java-Themen 10
D WSDL-Aufruf funktioniert nicht mehr nach Umstieg auf Maven Allgemeine Java-Themen 4
H KNN Erkennt Zahl Nicht Allgemeine Java-Themen 7
W ICEpdf PDF-Dateien werden mit Java 21 nicht nicht mehr vollständig dargestellt Allgemeine Java-Themen 3
Zrebna Berechnung der Zeit funktioniert nicht wie erwartet: Date, GregorianCalendar Allgemeine Java-Themen 16
Zrebna Wieso sollte man Null-Prüfungen nicht mit Optional-Objekten nutzen? Allgemeine Java-Themen 13
kodela Textfeld nicht rechteckig Allgemeine Java-Themen 10
G Doppelklick auf Javaprogramm klapt nicht Allgemeine Java-Themen 1
W Timer terminiert nicht Allgemeine Java-Themen 5
D Linux, Java-Version wird nicht erkannt bzw. welche Einstellung fehlt noch? Allgemeine Java-Themen 19
W Überflüssige Deklaration vermeiden...war da nicht mal was? Allgemeine Java-Themen 3
N lwjgl kann textureSampler nicht finden Allgemeine Java-Themen 4
P Fehler: Hauptklasse Main konnte nicht gefunden oder geladen werden Ursache: java.lang.ClassNotFoundException: Main Allgemeine Java-Themen 24
S Java Programm lässt sich vom USB-Stick starten, aber nicht von HDD Allgemeine Java-Themen 16
T .Jar kann man nicht ausführen Allgemeine Java-Themen 18
P JDK nicht installiert in Net Object Fusion Allgemeine Java-Themen 7
D Image bewegt sich nicht nach Klicken auf Button Allgemeine Java-Themen 15
N Regex schlägt nicht an Allgemeine Java-Themen 10
Y Wieso krieg ich die Unit Tests nicht hin Allgemeine Java-Themen 55
D Erste Schritte Mp3 Datei kann nicht von der Festplatte geöffnet werden - mit ChatGPT erstellt Allgemeine Java-Themen 7
G Popup wird nicht sichtbar Allgemeine Java-Themen 9
8u3631984 Funktions Parameter mit Lombok "NonNull" annotieren wird in Jacococ Testcoverage nicht herausgefiltert Allgemeine Java-Themen 3
kodela String kann nicht zu Pfad konvertiert werden Allgemeine Java-Themen 16
M Apache Proxy Weiterleitung auf Tomcat funktioniert nicht wie gewünscht Allgemeine Java-Themen 1
Momo16 Brauche Hilfe - Java Projekt kann nicht erstellt werden Allgemeine Java-Themen 12
OnDemand ApacheCommon FTP Client zuckt nicht Allgemeine Java-Themen 3
T JavaPoet - (noch) nicht existente Typen Allgemeine Java-Themen 2
E Es ist nicht möglich, eine Batch-Anweisung auszuführen. Allgemeine Java-Themen 9
C Was passt hier nicht bei der Calendar-Class Allgemeine Java-Themen 2
T Testing JUnit5: try ... catch arbeitet nicht sauber Allgemeine Java-Themen 6
W While Schleife funktioniert nicht ganz Allgemeine Java-Themen 4
OnDemand MemoryLeak nicht zu finden Allgemeine Java-Themen 26
torresbig Website login Problem - Jsoup, wie bisher, klappt nicht! Allgemeine Java-Themen 31
H do-while Schleife funktioniert nicht wie ich es möchte Allgemeine Java-Themen 7
ERlK JDA Code funktioniert nicht? Allgemeine Java-Themen 4
OnDemand Ram Freigabe erfolgt nicht nach Prozessende Allgemeine Java-Themen 18
OnDemand XML desializing Attribute bringt nicht erwartetes Ergebnis Allgemeine Java-Themen 16
T ImageIcon wird nicht angezeigt Allgemeine Java-Themen 6
N JAVA-Code mit Grafikfenster zeichnet in Windows, aber nicht Mac. Allgemeine Java-Themen 4
stormyark TikTakToe funktioniert nicht Allgemeine Java-Themen 10
N Warum wird die For Schleife nicht betreten Allgemeine Java-Themen 4
Tiago1234 Hauptklasse konnte nicht gefunden oder geladen werden Allgemeine Java-Themen 38
T Remove bei ArrayList funktioniert nicht Allgemeine Java-Themen 2
M Map<String,String>funktioniert nicht richtig Allgemeine Java-Themen 4
I "Neues" Lizenzmodell Oracle - JRE nicht mehr zur Redistribution freigegeben? Allgemeine Java-Themen 16
J c Programm läuft nicht in compilierter Version des Java Projektes Allgemeine Java-Themen 7
A code wird nicht ausgeführt Allgemeine Java-Themen 3
Blender3D Alte Beiträge nicht mehr vorhanden Allgemeine Java-Themen 6
M Warum hat Java dieses und jenes nicht... Allgemeine Java-Themen 8
W Bilder werden in App mit Jar-Datei nicht angezeigt Allgemeine Java-Themen 15
Micha43 Applet *.jar läuft nicht auf dem Mac Allgemeine Java-Themen 8
M Warum bekommen ich den Result nicht ? Allgemeine Java-Themen 17
Kiki01 Häufigster Buchstabe lässt sich nicht ermitteln Allgemeine Java-Themen 30
OnDemand RegEx /compilebekomme nicht die erwarteten Werte Allgemeine Java-Themen 9
HerrBolte Seltsamer Fehler nur in der Windows- und nicht in der Java-Console O_O Allgemeine Java-Themen 16
P String.replace() funktioniert nicht? Allgemeine Java-Themen 3
N nicht einsehbarer Fehler im code, kann nicht mehr übersetzten Allgemeine Java-Themen 51
P Karate API Test läuft nicht durch . initializationError Allgemeine Java-Themen 21
N nicht static und auch nicht new Allgemeine Java-Themen 3
Z macOS java konnte nicht entfernt werden xpc verbindungsfehler Allgemeine Java-Themen 4
T Schaltfläche wird nicht gefunden Allgemeine Java-Themen 4
boschl2000 Springerproblem-Implementierung funktioniert nicht richtig Allgemeine Java-Themen 1
F Getter Methode aufrufen funktioniert nicht Allgemeine Java-Themen 1
N Gierigen Regex in nicht-gierigen umwandeln Allgemeine Java-Themen 4
N Regulärer Ausdruck funktioniert nicht Allgemeine Java-Themen 6
AleXusher Hauptklasse startlösung konnte nicht gefunden oder geladen werden Allgemeine Java-Themen 1
G @PostConstruct Annotation nicht mehr gültig ? Allgemeine Java-Themen 7
L Objekte in Set nicht gefunden Allgemeine Java-Themen 13
T Projekt baut nicht mehr/lässt sich nicht mehr ausführen Allgemeine Java-Themen 6
izoards log4j2 will nicht.... Allgemeine Java-Themen 15
Tobero Meine Funktion für das beinhalten eines Punktes in einem Kreis funktioniert nicht Allgemeine Java-Themen 5
1Raini Java if-Abfrage funktioniert nicht! Allgemeine Java-Themen 3
D Firebase retrieve data Problem, Child Element wird nicht angesprochen Allgemeine Java-Themen 0
I serialVersionUID - explizit vergeben oder nicht? Allgemeine Java-Themen 6
MiMa Vorhandenes das nicht existiert?? Allgemeine Java-Themen 7
LimDul Hä? Lambda-Ausdruck geht, Methoden-Referenz nicht Allgemeine Java-Themen 8
O Jar lässt sich auf bestimmten Pc nicht starten Allgemeine Java-Themen 18
T Fremde Typen mockt man nicht? Allgemeine Java-Themen 3
Killunox MaxHeap Zuweisung unter Linux funktioniert nicht Allgemeine Java-Themen 1
LimDul Direktes return eines Array geht nicht Allgemeine Java-Themen 20
B neuroph hält beim XOR lernen nicht an Allgemeine Java-Themen 13
kodela JDialog zeigt Text nicht an Allgemeine Java-Themen 5
Dann07 Java-Programm findet DLLs nicht! Allgemeine Java-Themen 20
D Twitch API mit HttpURLConnection läuft nicht? Allgemeine Java-Themen 0
M Test geht auf Travis und mit Github Action schief aber nicht lokal Allgemeine Java-Themen 3
R Threads Clip loop loopt nicht Allgemeine Java-Themen 2
Dann07 MP3 Datei abspielen funktioniert nicht Allgemeine Java-Themen 6
W Server-Thread schreibt nicht alle Dateien Allgemeine Java-Themen 6
OnDemand JMS Messages nicht abgeholt Allgemeine Java-Themen 0
O Aus JAR-Datei erstellte EXE-Datei funktioniert nicht Allgemeine Java-Themen 10
A Mp3 Player funktioniert nicht Allgemeine Java-Themen 0
W String -> byte[] -> String - Sieht jemand was ich nicht sehe? Allgemeine Java-Themen 10
M Console geht nicht auf (Windows 10) Allgemeine Java-Themen 3
J Hilfe, Jar Datei kann nicht ausgeführt werden Allgemeine Java-Themen 2
W Enumeration ein Array/List als Eigenschaft mitgeben - warum geht das nicht? Allgemeine Java-Themen 0
W Javac nicht bei Installation installiert Allgemeine Java-Themen 9
S HTML den ich von einer URL hole nicht identisch mit dem HTML im Browser Allgemeine Java-Themen 1
S Java.exe exestiert, aber irgendwie auch nicht Allgemeine Java-Themen 11
D ArrayListe delete Methode klappt nicht Allgemeine Java-Themen 12
M Programm erkennt String aus .txt Datei nicht Allgemeine Java-Themen 3

Ähnliche Java Themen

Neue Themen


Oben