<?xml version="1.0"?>
<feed xmlns="http://www.w3.org/2005/Atom" xml:lang="de">
	<id>https://wiki-de.moshellshocker.dns64.de/index.php?action=history&amp;feed=atom&amp;title=Digital_Signature_Algorithm</id>
	<title>Digital Signature Algorithm - Versionsgeschichte</title>
	<link rel="self" type="application/atom+xml" href="https://wiki-de.moshellshocker.dns64.de/index.php?action=history&amp;feed=atom&amp;title=Digital_Signature_Algorithm"/>
	<link rel="alternate" type="text/html" href="https://wiki-de.moshellshocker.dns64.de/index.php?title=Digital_Signature_Algorithm&amp;action=history"/>
	<updated>2026-05-16T12:23:49Z</updated>
	<subtitle>Versionsgeschichte dieser Seite in Wikipedia (Deutsch) – Lokale Kopie</subtitle>
	<generator>MediaWiki 1.43.8</generator>
	<entry>
		<id>https://wiki-de.moshellshocker.dns64.de/index.php?title=Digital_Signature_Algorithm&amp;diff=176114&amp;oldid=prev</id>
		<title>imported&gt;Joschi71: /* Verdeckte Kanäle */ Stil</title>
		<link rel="alternate" type="text/html" href="https://wiki-de.moshellshocker.dns64.de/index.php?title=Digital_Signature_Algorithm&amp;diff=176114&amp;oldid=prev"/>
		<updated>2025-03-12T17:09:39Z</updated>

		<summary type="html">&lt;p&gt;&lt;span class=&quot;autocomment&quot;&gt;Verdeckte Kanäle: &lt;/span&gt; Stil&lt;/p&gt;
&lt;p&gt;&lt;b&gt;Neue Seite&lt;/b&gt;&lt;/p&gt;&lt;div&gt;Der {{lang|en|&amp;#039;&amp;#039;&amp;#039;Digital Signature Algorithm&amp;#039;&amp;#039;&amp;#039;}} (&amp;#039;&amp;#039;&amp;#039;DSA&amp;#039;&amp;#039;&amp;#039;; {{deS|„Digitaler Signaturalgorithmus“}}) ist ein Standard der [[Bundesregierung (Vereinigte Staaten)|US-Regierung]] für [[Digitale Signatur]]en. Er wurde vom [[National Institute of Standards and Technology]] (NIST) im August 1991 für die Verwendung in dessen &amp;#039;&amp;#039;{{lang|en|Digital Signature Standard}} (DSS)&amp;#039;&amp;#039; empfohlen. Der DSS enthielt neben dem DSA (ursprünglich der einzige im DSS definierte [[Algorithmus]]) als weitere Algorithmen die [[RSA-Kryptosystem|RSA-Signatur]] und [[Elliptic Curve DSA|ECDSA]]. Der DSS wurde zuerst in [[Federal Information Processing Standard|FIPS]]-PUB 186&amp;lt;ref&amp;gt;[[doi:10.6028/NIST.FIPS.186|FIPS-186]]&amp;lt;/ref&amp;gt; veröffentlicht und zuletzt wurde FIPS-PUB 186-4&amp;lt;ref name=&amp;quot;FIPS186-4&amp;quot;&amp;gt;[http://nvlpubs.nist.gov/nistpubs/FIPS/NIST.FIPS.186-4.pdf FIPS-186-4] (PDF; 776&amp;amp;nbsp;kB), die vierte  Revision.&amp;lt;/ref&amp;gt; durch PUB 186-5&amp;lt;ref name=&amp;quot;FIPS186-5&amp;quot;&amp;gt;[https://csrc.nist.gov/publications/detail/fips/186/5/final FIPS-186-5] die aktuelle Revision.&amp;lt;/ref&amp;gt; überarbeitet und ersetzt. Mit der Version 186-5 ist DSA ohne [[Elliptische Kurve|elliptische Kurven]] nicht mehr zulässig.&lt;br /&gt;
&lt;br /&gt;
Entworfen wurde er von der [[National Security Agency|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 [[Diskreter Logarithmus|diskreten Logarithmus]] in endlichen Körpern. Er orientiert sich am [[Elgamal-Signaturverfahren]] und ist verwandt mit der [[Schnorr-Signatur]]. Die Übertragung des DSA auf elliptische Kurven wird als &amp;#039;&amp;#039;&amp;#039;ECDSA&amp;#039;&amp;#039;&amp;#039; ({{lang|en|[[Elliptic Curve Cryptography|Elliptic Curve]] Digital Signature Algorithm}}) bezeichnet und ist in ANSI X9.62 standardisiert.&lt;br /&gt;
&lt;br /&gt;
[[Claus-Peter Schnorr]] warf im Rahmen der Standardisierung IEEE P1363 der NIST vor, mit dem von ihr entwickelten Signatur-Verfahren {{lang|en|Digital Signature Algorithm}} sein Patent zu verletzen. Dieses galt bis zum Jahre 2008. Vor der Entwicklung des DSA waren Verhandlungen mit Schnorr gescheitert, sein Signatur-Schema zu nutzen. Die Firma [[RSA Security|RSA]], die eine exklusive Lizenz an Schnorrs Signaturverfahren hält, hätte mit Patentstreitigkeiten ein Diskreter-Logarithmus-Verfahren statt ihres RSA-Systems als Standard erschweren können, scheute aber vermutlich eine offene Konfrontation mit der US-Regierung.&lt;br /&gt;
&lt;br /&gt;
== Funktionsweise ==&lt;br /&gt;
Für DSA wird ein Hashverfahren &amp;lt;math&amp;gt;H&amp;lt;/math&amp;gt; und eine mathematische [[Gruppe (Mathematik)|Gruppe]] benötigt. Als Hashverfahren war ursprünglich nur [[Secure Hash Algorithm|SHA-1]] zugelassen, in neueren Versionen des Standards wurde auch [[SHA-2]] zugelassen. Die Wahl der Gruppe hängt von zwei Parametern &amp;lt;math&amp;gt;L&amp;lt;/math&amp;gt; und &amp;lt;math&amp;gt;N&amp;lt;/math&amp;gt; ab, die die Sicherheit des Verfahrens bestimmen. Im ursprünglichen Standard wird &amp;lt;math&amp;gt;512\leq L\leq 1024&amp;lt;/math&amp;gt; und &amp;lt;math&amp;gt;N = 160&amp;lt;/math&amp;gt; gefordert, wobei &amp;lt;math&amp;gt;L&amp;lt;/math&amp;gt; ein Vielfaches von 64 sein muss. Der noch gültige Standard lässt folgende Kombinationen von &amp;lt;math&amp;gt;L&amp;lt;/math&amp;gt; und &amp;lt;math&amp;gt;N&amp;lt;/math&amp;gt; zu: (1024, 160), (2048, 224), (2048, 256), (3072, 256). &amp;lt;math&amp;gt;N&amp;lt;/math&amp;gt; darf höchstens so groß sein wie die Ausgabelänge des Hashalgorithmus.&lt;br /&gt;
&lt;br /&gt;
=== Parameter erzeugen ===&lt;br /&gt;
# Wähle eine Primzahl &amp;lt;math&amp;gt;q\,&amp;lt;/math&amp;gt; der Länge &amp;lt;math&amp;gt;N\,&amp;lt;/math&amp;gt; bit.&lt;br /&gt;
# Wähle eine Primzahl &amp;lt;math&amp;gt;p\,&amp;lt;/math&amp;gt; der Länge &amp;lt;math&amp;gt;L\,&amp;lt;/math&amp;gt; bit, so dass &amp;lt;math&amp;gt;p-1&amp;lt;/math&amp;gt; ein Vielfaches von &amp;lt;math&amp;gt;q\,&amp;lt;/math&amp;gt; ist.&lt;br /&gt;
# Wähle ein &amp;lt;math&amp;gt;g&amp;lt;/math&amp;gt;, das die [[Ordnung eines Gruppenelementes|Ordnung]] &amp;lt;math&amp;gt;q&amp;lt;/math&amp;gt; in der [[Einheitengruppe]] &amp;lt;math&amp;gt;(\Z/p\Z)^{\times}&amp;lt;/math&amp;gt; hat. Ein einfacher Weg, dies sicherzustellen ist, zuerst ein Gruppenelement &amp;lt;math&amp;gt;h\,&amp;lt;/math&amp;gt; mit &amp;lt;math&amp;gt;1&amp;lt;h&amp;lt;p-1\,&amp;lt;/math&amp;gt; und &amp;lt;math&amp;gt;h^{\frac{p-1}{q}}\mod p\neq 1&amp;lt;/math&amp;gt; zu finden und dann &amp;lt;math&amp;gt;g=h^{\frac{p-1}{q}}\mod p&amp;lt;/math&amp;gt; zu setzen. Die gewünschte Eigenschaft folgt dann aus dem [[Satz von Lagrange]] (Weil &amp;lt;math&amp;gt;h&amp;lt;/math&amp;gt; [[Teilerfremdheit|teilerfremd]] zur Primzahl &amp;lt;math&amp;gt;p&amp;lt;/math&amp;gt; ist, muss nach dem [[Kleiner fermatscher Satz|Kleinen Satz von Fermat]] &amp;lt;math&amp;gt;g^q=h^{p-1}=1 \mod p&amp;lt;/math&amp;gt; sein – die Ordnung von &amp;lt;math&amp;gt;g&amp;lt;/math&amp;gt; kann also höchstens &amp;lt;math&amp;gt;q&amp;lt;/math&amp;gt; sein. Da &amp;lt;math&amp;gt;q&amp;lt;/math&amp;gt; prim ist, kann die Ordnung von &amp;lt;math&amp;gt;g&amp;lt;/math&amp;gt; kein Teiler von &amp;lt;math&amp;gt;q&amp;lt;/math&amp;gt; sein.)&lt;br /&gt;
&lt;br /&gt;
Die Parameter &amp;lt;math&amp;gt;(p, q, g)&amp;lt;/math&amp;gt; sind öffentlich und können von mehreren Benutzern verwendet werden.&lt;br /&gt;
&lt;br /&gt;
=== Schlüssel erzeugen ===&lt;br /&gt;
# Wähle ein zufälliges &amp;lt;math&amp;gt;x\,&amp;lt;/math&amp;gt; für das gilt: &amp;lt;math&amp;gt;1&amp;lt;x&amp;lt;q\,&amp;lt;/math&amp;gt;&lt;br /&gt;
# Berechne &amp;lt;math&amp;gt;y=g^{x}\mod p&amp;lt;/math&amp;gt;&lt;br /&gt;
&lt;br /&gt;
Der Verifikationsschlüssel &amp;lt;math&amp;gt;y\,&amp;lt;/math&amp;gt; wird veröffentlicht ([[öffentlicher Schlüssel]]), der Signaturschlüssel &amp;lt;math&amp;gt;x\,&amp;lt;/math&amp;gt; muss geheim bleiben, da es der [[Geheimer Schlüssel|geheime Schlüssel]] ist.&lt;br /&gt;
&lt;br /&gt;
=== Signieren ===&lt;br /&gt;
Um die Nachricht &amp;lt;math&amp;gt;m\,&amp;lt;/math&amp;gt; zu signieren, reicht es auch, ihren Hashwert &amp;lt;math&amp;gt;H(m)&amp;lt;/math&amp;gt; zu signieren.&lt;br /&gt;
# Wähle für jede zu signierende Nachricht ein zufälliges &amp;lt;math&amp;gt;k\,&amp;lt;/math&amp;gt; mit &amp;lt;math&amp;gt;1&amp;lt;k&amp;lt;q\,&amp;lt;/math&amp;gt;&lt;br /&gt;
# Berechne &amp;lt;math&amp;gt;r=(g^{k}\mod p)\mod q&amp;lt;/math&amp;gt;; ist &amp;lt;math&amp;gt;r = 0&amp;lt;/math&amp;gt; so muss ein neues &amp;lt;math&amp;gt;k&amp;lt;/math&amp;gt; gewählt werden.&lt;br /&gt;
# Berechne &amp;lt;math&amp;gt;s=k^{-1} \cdot (H(m) + r \cdot x)\mod q&amp;lt;/math&amp;gt;; ist &amp;lt;math&amp;gt;s = 0&amp;lt;/math&amp;gt; so muss ebenfalls neu mit Schritt 1 begonnen werden&lt;br /&gt;
Die Signatur der Nachricht ist das Tupel &amp;lt;math&amp;gt;(r,s)\,&amp;lt;/math&amp;gt;. Der Wert &amp;lt;math&amp;gt;k&amp;lt;/math&amp;gt; muss geheim gehalten werden, darf nicht leicht zu erraten sein und darf nicht wiederverwendet werden, da sonst der [[Geheimer Schlüssel|geheime Signaturschlüssel]] &amp;lt;math&amp;gt;x&amp;lt;/math&amp;gt; berechnet werden kann (s. Abschnitt Sicherheit).&lt;br /&gt;
&lt;br /&gt;
=== Überprüfung ===&lt;br /&gt;
Gegeben ist eine Signatur &amp;lt;math&amp;gt;(r, s)&amp;lt;/math&amp;gt; sowie die Nachricht &amp;lt;math&amp;gt;m\,&amp;lt;/math&amp;gt;.&lt;br /&gt;
# Überprüfe, ob &amp;lt;math&amp;gt;0 &amp;lt; r &amp;lt; q&amp;lt;/math&amp;gt; und &amp;lt;math&amp;gt;0 &amp;lt; s &amp;lt; q&amp;lt;/math&amp;gt;. Ist das nicht der Fall, weise die Signatur als ungültig zurück.&lt;br /&gt;
# Berechne &amp;lt;math&amp;gt;w=s^{-1}\mod q&amp;lt;/math&amp;gt;&lt;br /&gt;
# Berechne &amp;lt;math&amp;gt;u_{1}=H(m)\cdot w\mod q&amp;lt;/math&amp;gt;&lt;br /&gt;
# Berechne &amp;lt;math&amp;gt;u_{2}=r\cdot w\mod q&amp;lt;/math&amp;gt;&lt;br /&gt;
# Berechne &amp;lt;math&amp;gt;v=(g^{u_1}\cdot y^{u_2}\mod p)\mod q&amp;lt;/math&amp;gt;&lt;br /&gt;
# Wenn &amp;lt;math&amp;gt;v=r\,&amp;lt;/math&amp;gt;, dann ist die Signatur gültig, sonst ungültig.&lt;br /&gt;
&lt;br /&gt;
== Sicherheit ==&lt;br /&gt;
&lt;br /&gt;
=== Anforderungen an Zufallswerte ===&lt;br /&gt;
Wie bei allen Signaturverfahren, die auf dem diskreten [[Logarithmus#Diskrete Logarithmen|Logarithmus]] basieren, insbesondere bei Verfahren, die auf [[Elliptische Kurve|elliptischen Kurven]] beruhen, hängt die Sicherheit ganz wesentlich von den Eigenschaften der berechneten Zufallswerte ab.&lt;br /&gt;
&lt;br /&gt;
Für jede Signatur muss ein Zufallswert &amp;lt;math&amp;gt;k&amp;lt;/math&amp;gt; generiert werden. Dieser muss ausreichend [[Entropie (Kryptologie)|Entropie]] besitzen, geheim gehalten werden und darf nur einmal verwendet werden. Diese Anforderungen sind kritisch: Wird der Wert &amp;lt;math&amp;gt;k&amp;lt;/math&amp;gt; bekannt, so kann aus der Signatur der geheime Signaturschlüssel berechnet werden: &amp;lt;math&amp;gt;x = (k \cdot s - H(m)) \cdot r^{-1} \mod q&amp;lt;/math&amp;gt;. Das ist ebenfalls möglich, wenn der gleiche Wert zweimal verwendet wird. Aus zwei mit dem gleichen &amp;lt;math&amp;gt;k&amp;lt;/math&amp;gt; signierten Nachrichten &amp;lt;math&amp;gt;m_1, m_2&amp;lt;/math&amp;gt; mit Signaturen &amp;lt;math&amp;gt;(r, s_1), (r, s_2)&amp;lt;/math&amp;gt; kann &amp;lt;math&amp;gt;k = (H(m_1) - H(m_2)) / (s_1 - s_2)&amp;lt;/math&amp;gt; berechnet werden. Damit wird dann wie eben &amp;lt;math&amp;gt;x&amp;lt;/math&amp;gt; berechnet. Falls &amp;lt;math&amp;gt;k&amp;lt;/math&amp;gt; nur geringe Entropie hat, kann ein Angreifer für jedes mögliche &amp;lt;math&amp;gt;k&amp;lt;/math&amp;gt; einen geheimen Schlüssel berechnen und dann mit Hilfe des öffentlichen Verifikationsschlüssels testen, welcher davon der richtige ist.&lt;br /&gt;
&lt;br /&gt;
=== Verdeckte Kanäle ===&lt;br /&gt;
[[Gustavus Simmons]] entdeckte mehrere verdeckte Kanäle in DSA. Damit kann ein Implementierer eine Nachricht in eine Unterschrift einschleusen, die nur jemand lesen kann, der den Schlüssel des verdeckten Kanals kennt. Kennt der Empfänger der Nachricht den geheimen Signaturschlüssel, ist der Kanal breitbandig. Teilen sich Sender und Empfänger ein [[gemeinsames Geheimnis]], ohne dass der Empfänger den geheimen Signaturschlüssel kennt, ist der Kanal schmalbandig. Laut Simmons sei es ein „bemerkenswerter Zufall“, dass die offensichtlichen Nachteile beim El-Gamal-Verfahren in DSS alle überwunden werden können und dass DSS die „günstigsten Voraussetzungen für verdeckte Kommunikation bietet, die bis heute entdeckt wurden“. Weder das NIST noch die NSA äußerten sich zu dem Vorwurf. Da ein böswilliger DSS-Entwickler über den verdeckten Kanal mit jeder Signatur Teile des geheimen Schlüssels versenden kann, darf man nur DSS-Implementierungen trauen, deren Entwicklern man völlig vertraut.&amp;lt;ref name=&amp;quot;Simmons93&amp;quot;&amp;gt;G.J. Simmons: &amp;#039;&amp;#039;The Subliminal Channels in the U.S. Digital Signature Algorithm (DSA).&amp;#039;&amp;#039; In: &amp;#039;&amp;#039;Proceedings of the Third Symposium on: State and Progress of Research in Cryptography.&amp;#039;&amp;#039; Fondazione Ugo Bordoni, Rom 1993, S.&amp;amp;nbsp;35–54.&amp;lt;/ref&amp;gt;&lt;br /&gt;
&lt;br /&gt;
== Einzelnachweise ==&lt;br /&gt;
&amp;lt;references /&amp;gt;&lt;br /&gt;
&lt;br /&gt;
[[Kategorie:Signaturverfahren]]&lt;/div&gt;</summary>
		<author><name>imported&gt;Joschi71</name></author>
	</entry>
</feed>