Digital Signature Algorithm
Un article de Wikipédia, l'encyclopédie libre.
Le Digital Signature Algorithm, plus connu sous le sigle DSA, est un algorithme de signature numérique standardisé par le NIST aux États-Unis, du temps où le RSA était encore breveté. Cet algorithme fait partie de la spécification DSS pour Digital Signature Standard adoptée en 1993 (FIPS 186). Une révision mineure a été publiée en 1996 (FIPS 186-1) et le standard a été amélioré en 2002 dans FIPS 186-2. Il est couvert par le brevet n° 5231668 aux USA (26 juin 1991), attribuée à David Kravitz, ancien employé de la NSA.
Sommaire |
[modifier] Aperçu
Le DSA est similaire à un autre type de signature développée par Claus Schnorr en 1989. Il a aussi des points communs avec la signature ElGamal. Le processus se fait en trois étapes :
- génération des clés
- signature du document
- vérification du document signé
[modifier] Générations des clés
- Choisir un nombre premier p de L-bit, avec 512 ≤ L ≤ 1024, et L est divisible par 64
- Choisir un nombre premier q de 160 bits, de telle façon que p − 1 = qz, avec z un entier
- Choisir h, avec 1 < h < p − 1 de manière à ce que g = hz mod p > 1
- Générer aléatoirement un x, avec 0 < x < q
- Calculer y = gx mod p
- La clé publique est (p, q, g, y). La clé privée est x
[modifier] Signature
- Choisir un nombre aléatoire s, 1 < s < q
- Calculer s1 = (gs mod p) mod q
- Calculer s2 = (H(m) + s1*x)s-1 mod q, où H(m) est le résultat d'un hachage cryptographique avec SHA-1 sur le message m
- La signature est (s1,s2)
[modifier] Vérification
- Rejeter la signature si 0<s1<q ou 0<s2<q n'est pas verifié
- Calculer w = (s2)-1 (mod q)
- Calculer u1 = H(m)*w (mod q)
- Calculer u2 = s1*w (mod q)
- Calculer v = [gu1*yu2 mod p] mod q
- La signature est valide si v = s1
[modifier] Validité de l'algorithme
Ce principe de signature est correct dans le sens où le vérificateur acceptera toujours des signatures authentiques. Ceci peut être démontré comme suit avec un exemple pratique :
À partir de g = hz mod p découle :
gq ≡ hqz ≡ hp-1 ≡ 1 (mod p) selon le petit théorème de Fermat. Puisque g>1 etq est premier, il s'ensuit que g a un ordre égal à q.
Celui qui procède à la signature effectue par exemple ceci (avec SHA-1) :
Ainsi
Comme g a un ordre q, on a :
Finalement, on aboutit à la validité de DSA :
[modifier] Voir aussi
- Rivest Shamir Adleman
- Signature numérique
- Cryptographie asymétrique
- Elliptic curve digital signature algorithm
![]() |
Portail de la cryptologie – Accédez aux articles de Wikipédia concernant la cryptologie. |