L'exercice suivant est automatiquement et aléatoirement généré par ataraXy.
Si vous regénérez la page (F5) les valeurs seront changées.
La correction se trouve en bas de page.
Exercice
On considère dans le système RSA, la clef publique \( (1333, 1171)\) .
- Déterminer deux entiers \( p\) et \( q\) tel que \( p {<} q\) et \( 1333=pq\) .
- Justifier que \( (1333, 1171)\) est une clef publique valide du cryptosystème RSA.
-
- Déterminer la décomposition de \( 1171\) en binaire.
- Calculer \( 12^{1171}\) modulo \( 1333\) .
- Quel est le message chiffré de \( M=12\) .
Déterminer la clef privé associée à la clef publique \( (1333, 1171)\) .
Déchiffrer le message \( M'=312\)
Cliquer ici pour afficher la solution
Exercice
- On observe que \( 1333=31\times 43\) .
- Pour vérifier que \( (1333, 1171)\) est une clef publique valide du cryptosystème RSA, il faut d'une part que \( 1333\) soit le produit de deux nombres premiers, ce que nous avons vérifier à la question précédente. Il faut d'autre part que \( 1171\) soit inversible modulo \( \phi=(p-1)(q-1)=30\times42=1260\) . Ce qui se vérifie avec l'algorithme d'Euclide :
\[\begin{array}{|c|c|c|c||c|c|}\hline
a&b&r&q&u&v \\ \hline
1260 & 1171 & 89 & 1&250 & -269 \\ \hline
1171 & 89 & 14 & 13&-19 & 250 \\ \hline
89 & 14 & 5 & 6&3 & -19 \\ \hline
14 & 5 & 4 & 2&-1 & 3 \\ \hline
5 & 4 & 1 & 1&1 & -1 \\ \hline
4 & 1 & 0 & 4&0 & 1 \\ \hline
\end{array}\]
-
- Le nombre \( 1171\) en binaire s'écrit \( 10010010011\) .
- On appliquel'algorithme d'exponentiation modulaire :
\[
\begin{array}{r|*{11}{|c}}
k & 0 & 1 & 2 & 3 & 4 & 5 & 6 & 7 & 8 & 9 & 10\\\hline12^{2^k} & 12 & 144 & 20736 & 549081 & 1483524 & 1507984 & 130321 & 1040400 & 435600 & 1085764 & 492804\\mod\ 1333 & \fbox{12} & \fbox{144} & 741 & 1218 & \fbox{1228} & 361 & 1020 & \fbox{660} & 1042 & 702 & \fbox{927}
\end{array}
\]
Finalement \( 12^{1171}=105\)
- Lorsque l'on applique le processus de chiffrement RSA avec \( (1333, 1171)\) comme clef publique a un message \( M\) , il faut réaliser l'opération \( M^e\% n\) soit ici \( M=12\) soit \( 12^{1171}\) modulo \( 1333\) que nous avons fait à la question précédente. Le chiffrement de \( M=12\) est donc \( 105\) .
Pour déterminer la clef privé associée à \( (1333, 1171)\) , il suffit de déterminer l'inverse de \( 1171\) modulo \( 1260\) . Nous avons précédement appliquer l'algorithme d'Euclide étendue. Nous observons donc que la clef privé est \( (1333, 991)\) .
Comme précédement on va appliquer l'algorithme d'exponentiation modulaire rapide pour calculer \( 312^{991}\) modulo \( 1333\) .
\[
\begin{array}{r|*{10}{|c}}
k & 0 & 1 & 2 & 3 & 4 & 5 & 6 & 7 & 8 & 9\\\hline312^{2^k} & 312 & 97344 & 1225 & 1500625 & 1000000 & 62500 & 1397124 & 19600 & 879844 & 4096\\mod\ 1333 & \fbox{312} & \fbox{35} & \fbox{1225} & \fbox{1000} & \fbox{250} & 1182 & \fbox{140} & \fbox{938} & \fbox{64} & \fbox{97}
\end{array}
\]
Finalement le déchiffrement de \( 312\) est \( 64\) .