s n h m r u
i

Diffie-Hellman-Schlüsselaustausch

Symmetrische Verschlüsselungsverfahren bieten vor allem im Bezug auf die Geschwindigkeit einen großen Vorteil. Ein zentrales Problem ist dabei aber die große Anzahl von Schlüsseln und deren sicherer Austausch zwischen den Kommunikationspartner:innen.

Die zentrale Frage ist: Kann man einen Schlüssel über ein unsicheres Medium austauschen?
Die beiden Wissenschaftler Whitfield Diffie und Martin Hellman haben 1976 festgestellt: Ja, man kann.

Der Algorithmus in Farbe

Die Mathematik hinter dem Algorithmus ist leider nicht ganz einfach zu verstehen. Dafür gibt es aber eine schöne Analogie mit Farben, die man zum Verständnis nutzen kann.

Der Ablauf:

  1. Alice und Bob einigen sich auf eine gemeinsame (öffentliche) Farbe.
  2. Jede:r wählt sich zudem eine geheime weitere Farbe.
  3. Alice und Bob mischen sich aus ihrer geheimen und der öffentlichen Farbe eine weitere Farbe.
  4. Sie schicken jeweils die neu gemischte Farbe zu ihrer Kommunikationspartner:in.
  5. Am Ende mischt jede:r ihre geheime Farbe in die zuvor ausgetauschten Mischfarbe.

Das folgende Video veranschaulicht das mit Cocktails an einer Bar:

Brick-Film des Mathematikums Gießen [1]

Die gemeinsame Farbe (der gemeinsame Cocktail) am Ende des Prozesses besteht also aus drei gemischten Farben. Und Eve in der Mitte?
Sie hat nur die öffentliche Farbe und zwei gemischte Farben. Und wie du vielleicht aus dem Kunstunterricht weißt, ist es ziemlich schwierig, aus einer Mischfarbe zu erkennen, welche Ausgangsfarben genau darin stecken.

Du kannst das hier einmal selbst nachspielen:

Der Algorithmus mit Zahlen

Das mathematische Verfahren beruht auf dem sog. "modularen Potenzieren", das du vielleicht noch im Kapitel zum RSA-Verfahren kennenlernen wirst. Auch wenn der mathematische Hintergrund nicht so einfach zu verstehen ist, kannst du das Verfahren aber sicherlich einmal hier nachvollziehen. Die wesentlichen Schritte sind (ganz analog zu den Farben oben) die Folgenden:
(Zur Erinnerung: Modulo (mod) ist eine Funktion, die den Rest einer Division berechnet.)

  1. Alice und Bob einigen sich auf zwei öffentliche Zahlen: Eine (in der Wirklichkeit sehr große) Primzahl $p$ und eine (kleinere) Zahl $g$.
  2. Beide wählen sich jeweils eine zufällige geheime Zahl, die ebenfalls kleiner als $p$ ist (Alice: $a$ und Bob: $b$).
  3. Aus der öffentlichen und ihrer geheimen Zahl berechnen beide jeweils eine neue Zahl
    Alice: $A := g^a \mod p$
    Bob:   $B := g^b \mod p$
  4. Diese Zahlen werden wieder über den öffentlichen Kanal ausgetauscht und damit können dann beide den gemeinsamen Schlüssel berechnen:
    Alice: $k_1 = B^a \mod p$
    Bob:   $k_2 = A^b \mod p$
  5. Der gemeinsame Schlüssel ist dann $k=k_1 = k_2$.

Du kannst das hier einmal ausprobieren:

Anmerkung: Das Verfahren funktioniert sogar auch dann noch, wenn die Zahlen g, a oder b größer als p gewählt werden. Allerdings bringt dies keine zusätzliche Sicherheit, sondern nur eine größere Rechenlast mit sich.

Aufgabe 1

Versuche einmal, mit einem Python-Dialog diese Rechnung nachzuvollziehen.
Beachte vor allem, welche riesigen Zahlen bei den Potenzen entstehen.

Hintergrund: Um diese zu vermeiden, gibt es ein besonderes Verfahren zum schnellen modularen Potenzieren, das du ebenfalls im Kapitel zu RSA kennenlernen kannst.

Vergleich Diffie-Hellman mit Zahlen/mit Farben

Quelle Diffie-Hellman-App mit Farben:
Verändert von SVG Diffie-Hellman, Urheber: A.J. Han Vinck, University of Duisburg-Essen; SVG version: Flugaal; German translation: Chillvie - A.J. Han Vinck, Introduction to public key cryptography, p. 16 [2]

Aufgabe 2

Das Diffie-Hellman-Verfahren mit Farben ist natürlich nur eine Analogiebeispiel, das dir helfen soll, das Verfahren besser zu verstehen. Ordne jeweils die Farben den Variablen beim echten Diffie-Hellman-Verfahren mit Zahlen zu.

Quellen

Suche

v
11.3.9
inf-schule.de/kryptologie/modernechiffriersysteme/exkurs_diffie
inf-schule.de/11.3.9
inf-schule.de/@/page/Qv4yXU7hNurvEWgL

Rückmeldung geben