Attaque de Wiener
L’attaque de Wiener, du nom du cryptologue Michael J. Wiener[1], est une attaque cryptographique contre le chiffrement RSA, utilisable lorsque l'exposant privé d est petit[2].
Rappels sur le RSA
modifierLe système RSA est un système de chiffrement à clé publique. Alice et Bob sont deux personnes voulant communiquer de façon sécurisée. Plus précisément, Alice veut envoyer à Bob un message qu'il sera le seul à pouvoir déchiffrer. Tout d'abord Bob choisit deux nombres premiers p et q, puis il calcule le module n = pq. Il calcule ensuite où est la fonction indicatrice d'Euler. Bob choisit ensuite un entier e inférieur et premier à qui sera appelé exposant de chiffrement, puis calcule son inverse modulo n, c'est-à-dire que .
Le théorème RSA stipule qu'on a alors . Bob envoie alors le couple (n,e) appelé clé publique et garde pour lui le couple (n,d) appelé clé privée. Pour chiffrer le message M, Alice fait l'opération et elle transmet le message chiffré C à Bob. Pour déchiffrer, Bob calcule et retrouve ainsi le message d'origine.
Si on connaît la factorisation de n, on peut facilement récupérer la clé secrète d en utilisant l'algorithme d'Euclide; et en connaissant la clé secrète d, on peut facilement retrouver la factorisation de n.
Conditions d'utilisation et énoncé du théorème
modifierL'attaque de Wiener consiste à retrouver d à partir de la clé publique (n,e).
Le théorème de Wiener dit que lorsque les conditions (d trop petit) et (qui signifie que p et q ont le même nombre de chiffres en binaire, ce n'est pas une hyptohèse restrictive pour utiliser RSA) sont remplies, il est facile de retrouver d.
Ce résultat peut être amélioré en remarquant (dans la démonstration qui suit) que entraîne (pour cela on multiplie simplement par l'inégalité de droite). Cela permet d'imposer une condition moins restrictive : .
Principe de l'attaque
modifierComme , il existe un entier k vérifiant .
Alors on a et .
L'attaquant va alors utiliser comme approximation de car et donc du fait que .
On obtient alors :
Or, donc .
D'où : .
Le nombre de fractions (avec d<n) qui approchent de si près est borné par log2(n). En fait, tous les nombres rationnels qui satisfont cette inégalité sont des réduites du développement en fraction continue de , d'après un résultat classique sur les fractions continues[3],[4]. L'attaquant n'a plus qu'à calculer les log(n) premières réduites du développement en fraction continue de , l'un d'eux sera égal à (qui est une fraction irréductible car comme , on a ).
Un algorithme en temps linéaire suffit alors pour retrouver la clé secrète d.
Notes et références
modifier- Wiener 2002.
- Menezes, van Oorschot et Vanstone 2001, Sec. 8.8 Notes and further references ; §8.2.
- Arithmétique: primalité et codes, théorie analytique des nombres, équations diophantiennes, courbes elliptiques, Calvage et Mounet, (ISBN 2-916352-04-X), « chap. Équation de Pell-Fermat »
- G. H. Hardy, E. M. Wright et Joseph Silverman, An Introduction to the Theory of Numbers, Oxford New York Auckland, Oxford University Press, USA, (ISBN 978-0-19-921985-8), théorème 184
Annexes
modifierBibliographie
modifier- [Wiener 2002] (en) Michael J. Wiener, « Cryptanalysis of Short RSA Secret Exponents », IEEE Transactions on Information Theory, (DOI 10.1109/18.54902, lire en ligne [PDF])
- [Menezes, van Oorschot et Vanstone 2001] (en) Alfred J. Menezes, Paul C. van Oorschot et Scott A. Vanstone, Handbook of Applied Cryptography, Boca Raton, CRC Press, , 5e éd. (1re éd. 1996), 816 p. (ISBN 978-0-8493-8523-0, BNF 37515673, présentation en ligne, lire en ligne [PDF]), chap. 8 (« Public Key Encryption »).
- « Twenty years of attacks on the RSA cryptosystem », Notices of the American Mathematical Society, vol. 46, , p. 203-213
Liens externes
modifier- Nicolas Douziech et Thomas Jannaud, Attaque de clés RSA par la méthode de Wiener
- (en) Dan Boneh, Twenty years of attacks on the RSA cryptosystem
- Forum sur la cryptographie