String-Verschlüsselung - Frage zur Sicherheit

Pariser

Mitglied
Hallo.

Ich habe vor einen String zu verschlüsseln. Dazu wird der char-Array des Strings durch eine For-Loop gejagt. Es gibt dabei ein Passwort von sagen wir mal 20 Zeichen, die nach einander dran kommen. In der For-Loop selbst gibt es einen bestimmten Algorithmus, der den aktuellen char in Absprache mit dem Passwort verändert.

Der String – ein großes Text-Dokument – wird so komplett verschlüsselt.

Ich werde danach nicht nur den Schlüssel festhalten. Sondern auch die App dafür. Quasi die For-Loop mit dem Algorithmus, der den Text entschlüsseln kann.
Wenn jemand den Text entschlüsseln will, braucht er quasi nicht nur den Schlüssel, sondern auch die App, bzw. das Wissen um den Algorithmus, der den Text verschlüsselt hat. Ich werde mir den Code einfach merken.

Ich hoffe, ich habe den Gedanken verständlich vermittelt.

Was haltet Ihr von so einem Ansatz?

Ich will einige Dokumente verschlüsseln, und sie so sich selbst per Email schicken. Dann liegen sie halt auf dem Email-Server, und werden höchstwahrscheinlich ewig dort bleiben.
Wenn jetzt jemand doch an diese Dateien gelangen könnte – besteht die Chance, dass man diese doch entschlüsseln kann, auch ohne das Wissen um das Passwort und den Algorithmus?
 

mihe7

Top Contributor
Was haltet Ihr von so einem Ansatz?
Nichts.

1. Sicherheit wird nicht durch Geheimhaltung von Algorithmen erreicht (
)
2. Keine Verschlüsselung ist ewig sicher

Mal abgesehen davon, dass man bei der Entwicklung kryptographischer Algorithmen viel falsch machen kann, machst Du Dir die Sache unnötig schwer. Nimm einfach etwas fertiges, wie z. B. AES. Als Schlüssel verwendest Du einen kryptographischen Hash Deines "Passworts", das Du Dir merkst. Wenn Du den Algorithmus trotzdem geheimhalten willst, brauchst Du ja keinen Hinweis darauf zu geben.
 

mihe7

Top Contributor
Dreiste Unterstellung. Das wäre ja, als ob hierzulande staatliche Einrichtungen Trojaner auf Computern installieren würden, um Zugriff auf dieselben zu erhalten. :eek:
 

Blender3D

Top Contributor
Dreiste Unterstellung. Das wäre ja, als ob hierzulande staatliche Einrichtungen Trojaner auf Computern installieren würden, um Zugriff auf dieselben zu erhalten
Du hast recht das kann natürlich gar nicht sein. Schließlich ist die NSA ja nur da zu da, um abhören zu verhindern und nicht um selbst so etwas zu tun.;)
 

Pariser

Mitglied
Kerckhoff’s Prinzip. Ich kann die Erklärung nicht nachvollziehen. Wenn ich nicht nur das Passwort, sondern auch den Algorithmus von allen fernhalte – wie will dann ein anderer den Text entschlüsseln? Wenn er zumindest den Algorithmus hätte, könnte er es per Brute Force versuchen. Doch wenn der Password lang und viele unterschiedliche Zeichen verwendet, wird es eine sehr langfristige Angelegenheit.

Wenn er dann auch den Algorithmus nicht hat, dürfte es für ihn doch noch schwieriger werden. Dann müsste er für jeden einzelnen Algorithmus, den er auf gut Glück testet, wiederum Brute Force anwenden.

Ich habe mir gedacht – doppelt hält besser.

Könnt Ihr mir vielleicht noch genauer erklären, was gegen diesen Ansatz spricht?

Und würdet Ihr dann, wenn ich hierher einen verschlüsselten String reinstelle, diesen entziffern können? Und selbst wenn nicht – wie geht man denn bei sowas vor?

Und danke für die bisherigen Informationen, ich werde versuchen mich da reinfuchsen.
 
X

Xyz1

Gast
Probier's einfach aus. Der beste Indikator bist du selber, dass heißt, wenn du sensible Daten weitergibst, wird er wahrscheinlich sicher sein.
 

httpdigest

Top Contributor
Zu glauben, dass eine Verschlüsselung sicherer ist, wenn der Angreifer den Algorithmus nicht kennt, ist ein Irrglaube. Man sollte zuerst glauben: Häh?! Wenn der Angreifer den Algorithmus nicht kennt, dann muss er doch alle möglichen Algorithmen ausprobieren.
Die eigentliche Argumentation geht aber in eine andere Richtung: Jemand, der seinen Algorithmus nicht veröffentlicht und von erfahrenen Cryptoanalytikern und Mathematikern testen lässt, wird mit sehr sehr großer Sicherheit sehr große Sicherheitslücken im Algorithmus selber haben. Das Video ist das beste Beispiel dafür. Jemand mit nur ein wenig Cryptoanalyse-Verständnis wird sofort auf die Idee kommen, dass sich bei gleichem Dateiinhalt/Klartextinhalt aufgrund der sich wiederholenden Shifts auch Wiederholungen in dem Crypttext ergeben. Und solche Schwächen kann man dann schnell ausnutzen. Um sichere Algorithmen zu entwickeln, benötigt man wirklich wirklich sehr tiefes mathematisches Verständnis.
Ein ähnliches Problem hatte auch die Enigma-Maschine, wenn ich mich recht entsinne.

Nichtsdestotrotz halte ich aber das Risiko dafür, dass sich jemand dafür interessiert, deine Verschlüsselung zu knacken für gegen Null.
 
X

Xyz1

Gast
Zumindest im Film war das so.

Vom Crypt auf den Algorithmus zu schließen ist aber nochmal ein anderes Brett (denke ich).
 

Pariser

Mitglied
Und wenn ich jetzt den Code aus diesem Video übernehme, und nur ein anderes Passwort (das aus 20 langen Zahlen besteht) verwende, und damit einen Text verschlüssele, würdest Du (httpdigest) ihn dann entschlüsseln können?

Ich habe jetzt nicht genau verstanden, wo die "große Sicherheitslücke" genau sitzt. Selbst wenn man den Algorithmus kennt (so einfach er auch sein mag), muss man doch noch das Passwort knacken, und da bestehen unglaublich viele Möglichkeiten.

Wie würdet Ihr denn vorgehen, um so einen Passwort herzuleiten? Ihr würdet doch auch Brute Force verwenden, oder?

Und es hieß ja bereits am Anfang des Threads, dass AES auch nicht das Wahre ist.
 

thecain

Top Contributor
Dann nimm halt den Code wenn du unbedingt was eigenes willst. Es ist auf keinen Fall sicherer. AES-256 wurde meines Wissens noch nie geknackt.
Das hier war Verschwörungstheorie und Ironie (hoffe ich)
 

mrBrown

Super-Moderator
Mitarbeiter
Und wenn ich jetzt den Code aus diesem Video übernehme, und nur ein anderes Passwort (das aus 20 langen Zahlen besteht) verwende, und damit einen Text verschlüssele, würdest Du (httpdigest) ihn dann entschlüsseln können?
Wenn genügend verschlüsselter Text vorliegt: Ja.

Fordere @httpdigest doch mal mit 1, 2 Texten von Wikipedia heraus :p


Ich habe jetzt nicht genau verstanden, wo die "große Sicherheitslücke" genau sitzt. Selbst wenn man den Algorithmus kennt (so einfach er auch sein mag), muss man doch noch das Passwort knacken, und da bestehen unglaublich viele Möglichkeiten.

Wie würdet Ihr denn vorgehen, um so einen Passwort herzuleiten? Ihr würdet doch auch Brute Force verwenden, oder?
Nur wenn der Text kurz genug ist, lohnt sich Brute Force, ab eine gewissen Menge nutzt man eher Fehler im Verfahren, bei sowas wie diesem könnten z.B. Häufigkeitsanalysen sinnvoll sein.
 

mihe7

Top Contributor
Ich habe jetzt nicht genau verstanden, wo die "große Sicherheitslücke" genau sitzt. Selbst wenn man den Algorithmus kennt (so einfach er auch sein mag), muss man doch noch das Passwort knacken, und da bestehen unglaublich viele Möglichkeiten.
Grundsätzlich ist es natürlich keine schlechte Idee, dem potenziellen Angreifer so wenig Infos wie möglich an die Hand zu geben. Du machst es demjenigen nicht leichter, wenn Du verheimlichst, wie und was Du verschlüsselt hast. Du darfst nur nicht den Fehler machen, Dich darauf zu verlassen, dass ein solches Verheimlichen die Verschlüsselung sicher macht. Die erste Variante in dem Video produziert eine Ausgabe, bei der man z. B. recht schnell sieht, worum es geht; da kannst Du verheimlichen, was Du willst.

Wenn man den Algorithmus kennt, lassen sich Schwachstellen identifizieren. Bei dem Algorithmus im Video würde sogar ich als kryptographischer Laie erkennen, dass der Algorithmus auf Strings arbeitet und der Schlüssel wiederholt angewendet wird. Ersteres gibt einen Hinweis auf Text, letzteres führt dazu, dass gleiche Zeichen, die in einem gewissen Abstand (Schlüssellänge) im Text vorkommen, gleich kodiert werden. Dadurch hat man eine riesige Angriffsfläche.

Durch die Wiederholungen dürfte sich die Schlüssellänge schnell ermitteln lassen. Außerdem ist der Wertebereich des Klartexts ziemlich eingeschränkt, da es sich um Text handelt: das Gros besteht aus Buchstaben von A-Z bzw. a-z. Die Wahrscheinlichkeit ist also ziemlich groß, dass der verschlüsselte Wert auf einen unverschlüsselten Wert im Bereich 65-90 bzw. 97-122 abgebildet werden muss. Hinzu kommt, dass alle paar Zeichen ein Leerzeichen (32) folgen wird.

Des weiteren kann man darauf abzielen, dass bestimmte Buchstaben/-kombinationen häufig vorkommen werden. Auch sind bestimmte Buchstabenfolgen eher ungewöhnlich, was den Wertebereich von aufeinanderfolgenden Zeichen weiter einschränkt. Zudem lassen sich "Wörterbücher" heranziehen, um passende Wörter zu finden usw.

Kurz: Du kannst Dir ziemlich sicher sein, dass bei diesem Algorithmus mit entsprechenden Angriffen innerhalb kürzester Zeit jeder x-beliebige Schlüssel ermittelt werden könnte. Und das funktioniert bei starken Algorithmen eben nicht.

Wie schnell man sich beim Entwickeln und beim Einsetzen solcher Algorithmen verheben kann, sieht man, wenn man wie Du glaubt, dass das Addieren großer Zahlen auf ein einzelnes Zeichen etwas bringen würde: ein char ist ein 16-Bit-Wert. Auf den kannst Du addieren, was Du willst, mehr als 16-Bit kommen am Ende nicht raus.

Wenn Du etwas sicheres haben willst, nimm ein öffentlich bekanntes Verfahren. Diese wurden von Leuten auf ihre Sicherheit hin überprüft, die etwas davon verstehen. Und achte darauf, dass Du es richtig einsetzt.

Und es hieß ja bereits am Anfang des Threads, dass AES auch nicht das Wahre ist.
Das hieß es nicht (zumindest nicht ernsthaft ;-)), wobei davon auszugehen ist, dass es "das Wahre" generell nicht gibt.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
S Key (für AES-Verschlüsselung) aus String Allgemeine Java-Themen 4
B String Verschlüsselung Allgemeine Java-Themen 6
C EML Email Text in String wandeln Allgemeine Java-Themen 9
OnDemand Java String in Hashmap als Key NULL Allgemeine Java-Themen 27
JAnruVA Datentypen Berechneten String-Wert in Double umwandeln um weiter zu rechnen Allgemeine Java-Themen 7
M String Allgemeine Java-Themen 10
M Suche nach String mit unbekannten characters Allgemeine Java-Themen 53
kodela String kann nicht zu Pfad konvertiert werden Allgemeine Java-Themen 16
melaniemueller Einzelne Zeile aus einer txt Datei in einem String speichern Allgemeine Java-Themen 12
E Objekte in einen String packen und wieder laden Allgemeine Java-Themen 5
M Map<String,String>funktioniert nicht richtig Allgemeine Java-Themen 4
O String in Long Hexerdezimal umwandel Allgemeine Java-Themen 14
N String vergleichen. Allgemeine Java-Themen 27
P String.replace() funktioniert nicht? Allgemeine Java-Themen 3
SaschaMeyer Arbeitet String.split falsch? Allgemeine Java-Themen 4
M Switches ohne String Allgemeine Java-Themen 18
AmsananKING String Iteration Allgemeine Java-Themen 5
S Shuffle String aus if-clause Allgemeine Java-Themen 11
Besset Variablen Ist String = "" + int inordnung? Allgemeine Java-Themen 6
M Map <Long, String> zu Map<String, Long> Allgemeine Java-Themen 9
S String Encoding Verständnisproblem Allgemeine Java-Themen 22
N Prüfen, ob ein String 2x das selbe Zeichen hat Allgemeine Java-Themen 10
SaftigMelo Bug Fixen von String-spliten Allgemeine Java-Themen 8
Monokuma String List nach Zahlen und Worten sortieren Allgemeine Java-Themen 9
Kingamadeus2000 Alle mehrfach vorkommenden Buchstaben rekursiv aus einem String entfernen. Allgemeine Java-Themen 6
YohnsonM String - Aufteilung und Nutzung einzelner Chars Allgemeine Java-Themen 7
O Formatierte String ausgabe bei vier Variablen in einer Zeile Allgemeine Java-Themen 1
S String umbenennen: wie? Allgemeine Java-Themen 4
x46 String Format Fehler Allgemeine Java-Themen 2
S ISO 8601 -> getter / setter String Allgemeine Java-Themen 3
L String zu repräsentativen Wert Allgemeine Java-Themen 0
H Array mit dem Datentype String[] initializieren Allgemeine Java-Themen 7
L ArrayList mit String Arrays in ein Array umwandeln Allgemeine Java-Themen 1
L regex ganzer string? Allgemeine Java-Themen 2
L Ist ein string ein erlaubter variabel name? Allgemeine Java-Themen 2
Z JNA Cpp-DLL String Verwendung Allgemeine Java-Themen 2
A String auf Zahlen überprüfen Allgemeine Java-Themen 5
N String Array Eingabe Allgemeine Java-Themen 6
MiMa Datum von String zu LocalDateTime Allgemeine Java-Themen 8
W String -> byte[] -> String - Sieht jemand was ich nicht sehe? Allgemeine Java-Themen 10
R char aus String entfernen Allgemeine Java-Themen 10
LimDul Mittels Streams aus Strings A B C den String A, B und C machen Allgemeine Java-Themen 12
M Programm erkennt String aus .txt Datei nicht Allgemeine Java-Themen 3
P einen public <Optinal String> in einer anderen Klasse mit einem Int vergleichen Allgemeine Java-Themen 2
S Ini Text aus String parsen Allgemeine Java-Themen 1
T String-Manipulation beim Ablauf in Eclipse und als JAR-File Allgemeine Java-Themen 8
M String lässt sich nicht Zusammenfügen Allgemeine Java-Themen 10
Drachenbauer Wie kann ich das Wort "concrete" in einem String durch ein anderes Wort ersetzen lassen? Allgemeine Java-Themen 5
R Schlüsselworte "Throw new exception" gibt nicht den String als Fehlermeldung aus Allgemeine Java-Themen 2
R Variablen String mit split-Funktion aufteilen Allgemeine Java-Themen 7
F Datei in String-Array einlesen Allgemeine Java-Themen 8
S Marker aus String ermitteln Allgemeine Java-Themen 5
T Objekt mit String und Int aus TxT Datei erstellen Allgemeine Java-Themen 23
M Bei String.format ein Komma statt einem Punkt ausgeben lassen Allgemeine Java-Themen 1
S MSSQL Exception & Connection String Allgemeine Java-Themen 19
B Bei Email: FW / AW... - Hilfe bei String suche Allgemeine Java-Themen 21
J String - Vergleiche Allgemeine Java-Themen 7
K Aus String zwei Jahreszahlen auslesen Allgemeine Java-Themen 18
Drachenbauer Wie kann eine vorgegebene Farbe über einen String erkannt werden? Allgemeine Java-Themen 11
G CSV in String Allgemeine Java-Themen 7
K Methodenaufruf mit String / String zu Objekt konvertieren Allgemeine Java-Themen 8
D Erste Schritte Fehler mit negativen und 0 Zahlen im String Allgemeine Java-Themen 6
Xge Replace x Zeichen aus String Allgemeine Java-Themen 2
coolian warum bekomme ich ein string index out of bounds exception Allgemeine Java-Themen 17
F In String 2 Buchstaben vertauschen Allgemeine Java-Themen 2
J Class Decompile als String (Procyon) Allgemeine Java-Themen 2
I Datentypen String in class sicher verwahren Allgemeine Java-Themen 17
J Falls der String ein "X" beinhaltet Allgemeine Java-Themen 2
T String mehrere Worte Allgemeine Java-Themen 2
D String Groß-/Kleinschreibung Allgemeine Java-Themen 2
D String und Klassenvariable Allgemeine Java-Themen 6
Aruetiise Funktion(y = mx+n) in String speichern und berechnen Allgemeine Java-Themen 9
C String in Objektnamen umwandeln Allgemeine Java-Themen 3
E Variablen Aus .txt ausgelesener string mit if() überprüfen? Allgemeine Java-Themen 2
L String-Schema-Aufspaltung Allgemeine Java-Themen 2
E String in Zahl umwandeln, ohne Befehl Integer.parseInt Allgemeine Java-Themen 3
L String splitten und multiplizeren Allgemeine Java-Themen 10
G String mit umbekannter länge splitten. Allgemeine Java-Themen 2
S Einzigartigen String in Datenbank finden und löschen Allgemeine Java-Themen 23
A Byte zu String Allgemeine Java-Themen 4
B Von String zu <Objekt> ||Speichern/Laden Allgemeine Java-Themen 17
T Komplexitätsoptimierung String vergleich Allgemeine Java-Themen 4
heinz ketchup String im JLabel ausgeben und erneuern Allgemeine Java-Themen 6
S Input/Output Beste Möglichkeit einen String in einen Datei zu Schreiben Allgemeine Java-Themen 2
V Eingegeben String Splitten und in Integer umwandeln Allgemeine Java-Themen 2
L Decrypt String Allgemeine Java-Themen 1
X Variablen AtmicLong größer als String ? Allgemeine Java-Themen 4
S String literal und Referenzvariablen Allgemeine Java-Themen 6
J Datentypen Absätze mit String im Word Dokument Allgemeine Java-Themen 3
D "Paste" String doppelt Allgemeine Java-Themen 14
E String Frage Allgemeine Java-Themen 9
T String aus While Schleife für ganze Klasse sichtbar machen Allgemeine Java-Themen 5
D JSON to String Allgemeine Java-Themen 31
M String automatisch in nächste Zeile umbrechen (Graphics) Allgemeine Java-Themen 6
U Methoden Algorithmus MergeSort String [ ] array sortieren programmieren Allgemeine Java-Themen 17
T Swing Font String Pixellänge Allgemeine Java-Themen 1
G Substrings in einen String zusammenfassen Allgemeine Java-Themen 5
Tommy Nightmare String.replaceAll(...) fehlerhaft? Allgemeine Java-Themen 3
L String auf zahlenwert prüfen Allgemeine Java-Themen 13
U OOP Warum kann ich aus meiner Methode keinen String auslesen Allgemeine Java-Themen 4

Ähnliche Java Themen

Neue Themen


Oben