Die Hill-Chiffre ist ein Verschlüsselungsverfahren der klassischen Kryptographie. Sie ist eine polyalphabetische Substitution, basierend auf linearer Algebra. Erfunden wurde sie 1929 von Lester S. Hill, der Professor am Hunter College in New York City war und diese Methode erstmals in seinem Artikel „Cryptography in an Algebraic Alphabet“ publizierte. Der Klartext wird in Blöcke aus je aufeinanderfolgenden Zeichen unterteilt, und jeder Block wird durch Multiplikation mit einer Matrix als Ganzes substituiert. Die Hill-Chiffre war zu dieser Zeit das einzige polyalphabetische Verfahren, das theoretisch (wenn auch kaum in der Praxis) auf mehr als drei Klartextzeichen zugleich () operieren konnte.
Verschlüsselung
Jeder Buchstabe wird von einer Zahl modulo 26 repräsentiert. Meist wird die einfache Zuordnung A = 0, B = 1, …, Z = 25 verwendet, aber dies ist nicht zwingend. Um eine Botschaft zu verschlüsseln, wird ein Block von n Buchstaben (als n-Komponenten Vektor) mit einer invertierbaren n×n-Matrix – wieder modulo 26 – multipliziert. Um die Nachricht zu entschlüsseln, wird jeder Block mit dem Inversen der Matrix, die zur Verschlüsselung verwendet wurde, multipliziert.
Die Matrix, die zur Verschlüsselung verwendet wurde, ist der Schlüssel und sollte zufällig aus der Menge der invertierbaren n×n-Matrizen (modulo 26) gewählt werden. Die Chiffre kann natürlich an ein Alphabet mit beliebiger Anzahl von Buchstaben (abweichend von 26) angepasst werden. Alle arithmetischen Operationen müssen dann entsprechend modulo erfolgen. Außerdem lässt sich die Länge der Blöcke frei wählen, woraus sich die Größe der Matrizen und damit die Schlüssellänge ergibt.
In folgendem Beispiel wählen wir und den Schlüssel „GYBNQKURP“, der folgende Matrix ergibt, in die die Schlüsselbuchstaben als Zahlen codiert eingetragen werden:
Wir betrachten den Klartextblock „ACT“. Da A = 0, C = 2 und T = 19, ist der Klartextvektor:
Damit wird der Geheimtextvektor berechnet:
Dies entspricht dem Geheimtext „POH“. Angenommen, dass unsere Botschaft nun „CAT“ ist:
Mit der gleichen Verschlüsselungsmatrix wie oben ergibt sich:
was dem Chiffretext „FIN“ entspricht. Weil jeder Geheimtextbuchstabe aus allen drei Klartextbuchstaben berechnet wird, ändert sich jeder Buchstabe. Die Hill-Chiffre bewirkt also Diffusion über alle n Zeichen eines Blocks.
Entschlüsselung
Um den Geheimtext zu entschlüsseln, multiplizieren wir ihn mit der inversen Matrix zu der Verschlüsselungsmatrix (in Buchstaben ist diese „IFKVIVVMI“). (Um eine inverse Matrix zu berechnen, siehe Matrixinversion.) Dies ist die inverse Matrix der Verschlüsselungsmatrix aus dem vorigen Beispiel:
Wenn man sie auf den vorher verschlüsselten Geheimtext „POH“ anwendet, erhält man:
Dadurch erhält man wieder den Klartext „ACT“.
Als Verschlüsselungsmatrix muss eine invertierbare Matrix gewählt werden, damit dazu auch eine Entschlüsselungsmatrix existiert. Eine Matrix mit Ganzzahlen kann modulo invertiert werden dann und nur dann, wenn ihre Determinante ungleich Null und teilerfremd zur modularen Basis ist, d. h., dass die Determinante und keine gemeinsamen Teiler haben dürfen. Wenn wie oben ist, darf die Determinante nicht durch 2 oder 13 teilbar sein, sonst ist der Geheimtext nicht mehr zu decodieren. Glücklicherweise sind die Matrizen, die diese Bedingungen erfüllen, relativ häufig. Die Determinante der obigen Verschlüsselungsmatrix ist:
Da die Determinante 25 keine gemeinsamen Faktoren mit der Modulo-Zahl 26 hat, kann diese Matrix für die Hill-Chiffre verwendet werden. Das Risiko, dass die Determinante gemeinsame Faktoren mit der modularen Basis hat, kann vermindert werden, wenn man als modulare Basis eine Primzahl verwendet. Folglich ist eine nützliche Variante der Hill-Chiffre, noch drei Symbole zum Alphabet hinzuzufügen (z. B. Fragezeichen, Leerzeichen und Punkt) um auf die Primzahl 29 als modulare Basis zu kommen.
Es ist auch möglich, für die Verschlüsselungsmatrix eine involutive Matrix zu wählen, die mit ihrer Inversen identisch ist, also . Damit entfällt die aufwändige Bestimmung der inversen Matrix.
Sicherheit
Schlüsselraum
Für ein Alphabet mit Buchstaben ( sind verschiedene Primzahlen, also in Primfaktorzerlegung) umfasst der Schlüsselraum für n × n – Matrizen
- Schlüssel.
Der Schlüsselraum ist deshalb für Schlüssel einer Größenordnung am größten, wenn man als Primzahlpotenz wählt, also .
Die Hill-Chiffre ist völlig linear und daher für einen Angriff mit bekanntem Klartext anfällig. Es genügen Paare von Klartext- und Geheimtextvektoren, um ein lineares Gleichungssystem aufzustellen, mit dem die Verschlüsselungsmatrix in der Regel berechnet werden kann. Im ungünstigsten Fall braucht man ein wenig mehr als Paare, um eine eindeutige Lösung zu erhalten.
Siehe auch
Weblinks
- „Hill Chiffre“ erklärt, kodiert und dekodiert
- „Hill Cipher Web App“ kodiert und dekodiert die eingegebenen Botschaften und zeigt die verwendeten Matrizen
- „Hill Cipher Explained“ veranschaulicht die lineare Algebra hinter der Hill-Chiffrierung
- „Hill's Cipher Calculator“
Quellen
- ↑ Lester S. Hill: Cryptography in an Algebraic Alphabet. In: The American Mathematical Monthly. Band 36, Nr. 6, Juni 1929, S. 306, doi:10.2307/2298294 (marksmath.com [PDF; abgerufen am 11. Juni 2014]).
- ↑ Ryan Doyle: Hill’s Cipher: Linear Algebra in Cryptography (PDF-Datei).
- 1 2 Jeffrey Overbey, William Traves and Jerzy Wojdylo: On The Keyspace Of The Hill Cipher. Cryptologia (PDF; 143 kB).