Zum Inhalt springen

Digital Signature Algorithm

aus Wikipedia, der freien Enzyklopädie
Dies ist eine alte Version dieser Seite, zuletzt bearbeitet am 29. März 2007 um 14:16 Uhr durch Thijs!bot (Diskussion | Beiträge) (Bot: Ergänze: vi:Giải thuật ký số). Sie kann sich erheblich von der aktuellen Version unterscheiden.

Der Digital Signature Algorithm (DSA) ist ein Standard der US-Regierung für Digitale Signaturen. Er wurde vom National Institute of Standards and Technology (NIST) im August 1991 für die Verwendung in deren Digital Signature Standard (DSS) empfohlen. Der DSS (Digital Signature Standard) enthält neben dem DSA (ursprünglich der einzige im DSS definierte Algorithmus) als weitere Algorithmen die RSA-Signatur und ECDSA. Der DSS ist in FIPS-PUB 186-2 veröffentlicht. Der DSA ist im Unterschied zu RSA nicht zugleich auch als Verschlüsselungsverfahren konzipiert. Entworfen wurde er von der NSA im Rahmen des Versuchs der US-Regierung, hochsichere Verschlüsselung unter Kontrolle zu bringen. Bestandteil dieser Strategie war auch das Exportverbot starker Verschlüsselungsalgorithmen, dessen Missachtung strafrechtlich verfolgt wurde.

Der DSA basiert auf dem diskreten Logarithmus in endlichen Körpern. Er ist eng verwandt mit der Schnorr-Signatur und kann sogar als eine Variante oder Optimierung der Schnorr-Signatur angesehen werden. Die Übertragung des DSA auf elliptische Kurven wird als ECDSA bezeichnet und ist in ANSI X9.62 standardisiert.

Funktionsweise

Schlüssel erzeugen

  • Wähle eine Primzahl der Länge bit, mit , wobei ein Vielfaches von 64 ist.
  • Wähle eine weitere Primzahl der Länge 160 bit, für die gilt: ( Element der natürlichen Zahlen)
  • Wähle für das gilt: und
  • Berechne
  • Wähle ein zufälliges für das gilt:
  • Berechne

werden veröffentlicht (öffentlicher Schlüssel), bleibt geheim und wird somit zum geheimen Schlüssel.

Signieren

Signiert wird die Nachricht ; bezeichnet den SHA-1 Hashwert der Nachricht .

  • Wähle für jede zu signierende Nachricht ein zufälliges mit
  • Berechne
  • Berechne

Die Signatur der Nachricht ist nun .

Überprüfung

Gegeben ist die Signatur bestehend aus und sowie die Nachricht . Der Wert braucht nicht übermittelt zu werden.

  • Berechne
  • Berechne
  • Berechne
  • Berechne

Wenn , dann ist die Signatur gültig.