Sari la conținut

RSA: Diferență între versiuni

De la Wikipedia, enciclopedia liberă
Conținut șters Conținut adăugat
m completat intro
m wl
 
(Nu s-au afișat 24 de versiuni intermediare efectuate de alți 16 utilizatori)
Linia 1: Linia 1:
{{pentru|Republica Sud-Africană|Africa de Sud}}
În [[criptografie]], '''RSA''' este un algoritm criptografic cu chei publice, primul algoritm utilizat atât pentru criptare, cât şi pentru semnătura electronică. Algoritmul a fost dezvoltat în 1977 şi publicat în 1978 de [[Ron Rivest]], [[Adi Shamir]] şi [[Leonard Adleman]] la [[MIT]] şi îşi trage numele de la iniţialele numelor celor trei autori.<ref>Schneier, 1996, p. 385</ref>
În [[criptografie]], '''RSA''' este un algoritm criptografic cu chei publice, primul algoritm utilizat atât pentru criptare, cât și pentru semnătura electronică. Algoritmul a fost dezvoltat în 1977 și publicat în 1978 de [[Ron Rivest]], [[Adi Shamir]] și [[Leonard Adleman]] la [[MIT]] și își trage numele de la inițialele numelor celor trei autori.<ref>Schneier, 1996, p. 385</ref>


Puterea sa criptografică se bazează pe dificultatea [[Factorizarea întregilor|problemei factorizării numerelor întregi]], problemă la care se reduce criptanaliza RSA şi pentru care toţi algoritmii de rezolvare cunoscuţi au [[Teoria complexităţii|complexitate]] exponenţială. Există însă câteva metode de criptanaliză care ocolesc factorizarea efectivă, exploatând maniere eronate de implementare efectivă a schemei de criptare.
Puterea sa criptografică se bazează pe dificultatea [[Factorizarea întregilor|problemei factorizării numerelor întregi]], problemă la care se reduce criptanaliza RSA și pentru care toți algoritmii de rezolvare cunoscuți au [[Teoria complexității|complexitate]] exponențială. Există însă câteva metode de criptanaliză care ocolesc factorizarea efectivă, exploatând maniere eronate de implementare efectivă a schemei de criptare.


==Funcţionare==
== Funcționare ==
RSA este un algoritm de criptare pe blocuri. Aceasta înseamnă că atât textul clar cât şi cel cifrat sunt numere între ''0'' şi ''n''-1, cu un ''n'' ales. Un mesaj de dimensiune mai mare decât <math>log\,n</math> este împărţit în segmente de lungime corespunzătoare, numite ''blocuri'', care sunt cifrate rând pe rând.<ref>Stallings, 2005, p. 269</ref> De asemenea, ca algoritm criptografic cu chei publice, funcţionează pe baza unei perechi de chei legate matematic între ele: o cheie publică, cunoscută de toată lumea, şi una secretă, necunoscută decât de deţinătorul acesteia.
RSA este un algoritm de criptare pe blocuri. Aceasta înseamnă că atât textul clar cât și cel cifrat sunt numere între ''0'' și ''n''-1, cu un ''n'' ales. Un mesaj de dimensiune mai mare decât <math>log\,n</math> este împărțit în segmente de lungime corespunzătoare, numite ''blocuri'', care sunt cifrate rând pe rând.<ref>Stallings, 2005, p. 269</ref> De asemenea, ca algoritm criptografic cu chei publice, funcționează pe baza unei perechi de chei legate matematic între ele: o cheie publică, cunoscută de toată lumea, și una secretă, cunoscută doar de deținătorul acesteia.


===Generarea cheilor===
=== Generarea cheilor ===
Perechea de chei se generează după următorii paşi<ref>Menezes, p. 286</ref>:
Perechea de chei se generează după următorii pași<ref>Menezes, p. 286</ref>:
#Se generează două numere prime, de preferat mari, ''p'' şi ''q'';
# Se generează două numere prime, de preferat mari, ''p'' și ''q'';
#Se calculează <math>n\,=\,pq</math> şi <math>\phi\,=\,(p-1)(q-1)</math>
# Se calculează <math>n\,=\,pq</math> și <math>\phi\,=\,(p-1)(q-1)</math>
#Se alege un întreg aleator ''e'', <math>1 < e < \phi</math> astfel încât cmmdc(e, φ) = 1. Perechea (n, e) este cheia publică.
# Se alege un întreg aleator ''e'', <math>1 < e < \phi</math> astfel încât cmmdc(e, φ) = 1. Perechea (n, e) este cheia publică.
#Folosind [[algoritmul lui Euclid]] extins, se calculează întregul ''d'', unicul cu proprietatea că <math>de\,\equiv\,1\,mod\,\phi</math>. (n, d) constituie cheia secretă.
# Folosind [[algoritmul lui Euclid]] extins, se calculează întregul ''d'', unicul cu proprietatea că <math>de\,\equiv\,1\,mod\,\phi</math>. (n, d) constituie cheia secretă.


Decizia cu privire la care dintre ''e'' şi ''d'' este cheia publică şi care este cea secretă este, din punct de vedere matematic, arbitrară, oricare dintre cele două numere poate juca oricare dintre roluri<ref>Schneier, 1996, p. 387</ref>. În practică însă, pentru a mări viteza de criptare, şi întrucât dintre cele două numere ''e'' este cel ales arbitrar, ''e'' este cheia publică iar valoarea sa este aleasă un număr mic, de regulă 3, 17 sau 65537 (2<sup>16</sup>+1)<ref name="stallings_274">Stallings, 2005, p. 274</ref>. Aceasta conduce la un număr minim de înmulţiri, deci la o performanţă sporită, deoarece toate aceste numere au doar două cifre 1 în reprezentarea lor binară<ref name="stallings_274"/>.
Decizia cu privire la care dintre ''e'' și ''d'' este cheia publică și care este cea secretă este, din punct de vedere matematic, arbitrară, oricare dintre cele două numere poate juca oricare dintre roluri<ref>Schneier, 1996, p. 387</ref>. În practică însă, pentru a mări viteza de criptare, și întrucât dintre cele două numere ''e'' este cel ales arbitrar, ''e'' este cheia publică iar valoarea sa este aleasă un număr mic, de regulă 3, 17 sau 65537 (2<sup>16</sup>+1)<ref name="stallings_274">Stallings, 2005, p. 274</ref>. Aceasta conduce la un număr minim de înmulțiri, deci la o performanță sporită, deoarece toate aceste numere au doar două cifre 1 în reprezentarea lor binară<ref name="stallings_274"/>.


===Criptarea şi decriptarea===
=== Criptarea și decriptarea ===


Presupunând că mesajul clar este sub forma unui număr ''m'', mai mic decât ''n'', atunci mesajul cifrat, notat cu ''c'' este
Presupunând că mesajul clar este sub forma unui număr ''m'', mai mic decât ''n'', atunci mesajul cifrat, notat cu ''c'' este
:<math>c\,=\,m^e\,\pmod{n}</math>
:<math>c\,=\,m^e\,\pmod{n}</math>
unde ''e'' este cheia publică a destinatarului mesajului. Pentru a decripta mesajul, destinatarul îşi foloseşte cheia sa secretă ''d'', care are proprietatea foarte importantă că:
unde ''e'' este cheia publică a destinatarului mesajului. Pentru a decripta mesajul, destinatarul își folosește cheia sa secretă ''d'', care are proprietatea foarte importantă că:
:<math>de\,\equiv\,1\,mod\,\phi</math>
:<math>de\,\equiv\,1\,mod\,\phi</math>
Astfel, mesajul clar este recuperat calculând:
Astfel, mesajul clar este recuperat calculând:
Linia 26: Linia 27:
Oricine poate cripta mesaje cu cheia publică a destinatarului, dar numai acesta din urmă poate decripta, deoarece trebuie să folosească cheia sa secretă.
Oricine poate cripta mesaje cu cheia publică a destinatarului, dar numai acesta din urmă poate decripta, deoarece trebuie să folosească cheia sa secretă.


Algoritmul poate fi folosit şi pentru semnătura electronică, folosind cheile invers. Dacă o entitate criptează un mesaj (sau mai degrabă un [[Funcţie hash|hash]] al acestuia) cu cheia sa secretă şi ataşează rezultatul mesajului său, atunci oricine poate verifica, decriptând cu cheia publică a semnatarului şi comparând rezultatul cu mesajul clar (sau cu hash-ul acestuia), că într-adevăr acea entitate este autorul mesajului.
Algoritmul poate fi folosit și pentru semnătura electronică, folosind cheile invers. Dacă o entitate criptează un mesaj (sau mai degrabă un [[Funcție hash|hash]] al acestuia) cu cheia sa secretă și atașează rezultatul mesajului său, atunci oricine poate verifica, decriptând cu cheia publică a semnatarului și comparând rezultatul cu mesajul clar (sau cu hash-ul acestuia), că într-adevăr acea entitate este autorul mesajului.


====Demonstraţia formulei de decriptare====
==== Demonstrația formulei de decriptare ====
Formula de decriptare este valabilă, deoarece<ref>Demonstraţie similară cu cea din Menezes, p. 286</ref>:
Formula de decriptare este valabilă, deoarece<ref>Demonstrație similară cu cea din Menezes, p. 286</ref>:
:<math>c^d\,mod\,n\,=\,m^{ed}\,mod\,n</math>
:<math>c^d\,mod\,n\,=\,m^{ed}\,mod\,n</math>


:<math>ed \equiv 1 \pmod{\phi}</math> şi, fiindcă <math>\phi=(p-1)(q-1)</math>, atunci
:<math>ed \equiv 1 \pmod{\phi}</math> și, fiindcă <math>\phi=(p-1)(q-1)</math>, atunci
:<math>ed \equiv 1 \pmod{p-1}</math> şi
:<math>ed \equiv 1 \pmod{p-1}</math> și
:<math>ed \equiv 1 \pmod{q-1}</math>
:<math>ed \equiv 1 \pmod{q-1}</math>
şi deci se poate scrie:
și deci se poate scrie:
:<math>ed=k(p-1)+1</math>
:<math>ed=k(p-1)+1</math>
:<math>ed=h(q-1)+1</math>
:<math>ed=h(q-1)+1</math>


Dar, cum ''p'' este prim, şi deci prim cu m, conform [[Mica teoremă a lui Fermat|micii teoreme a lui Fermat]], rezultă că
Dar, cum ''p'' este prim, și deci prim cu m, conform [[Mica teoremă a lui Fermat|micii teoreme a lui Fermat]], rezultă că
:<math>m^{p-1}\,\equiv\,1\pmod{p}</math>
:<math>m^{p-1}\,\equiv\,1\pmod{p}</math>
Astfel,
Astfel,
:<math>m^{ed} = m^{k (p-1) + 1} = (m^{p-1})^k m \equiv {1}^k m = m \pmod{p}\,</math>.
:<math>m^{ed} = m^{k (p-1) + 1} = (m^{p-1})^k m \equiv {1}^k m = m \pmod{p}\,</math>.
Dacă ''p'' nu este totuşi prim cu ''m'', atunci înseamnă că ''m'' este multiplu al lui ''p'', caz trivial în care ''m'' este congruent cu 0 modulo ''p'', şi deci ridicat la orice putere este congruent cu 0 şi deci cu el însuşi.
Dacă ''p'' nu este totuși prim cu ''m'', atunci înseamnă că ''m'' este [[multiplu]] al lui ''p'', caz trivial în care ''m'' este congruent cu 0 modulo ''p'', și deci ridicat la orice putere este congruent cu 0 și deci cu el însuși.


Analog şi pentru ''q'', <math>m^{ed} \equiv m \pmod{q}</math>
Analog și pentru ''q'', <math>m^{ed} \equiv m \pmod{q}</math>


De aici, conform [[Teorema chinezească a resturilor|teoremei chinezeşti a resturilor]], deoarece ''p'' şi ''q'' sunt numere prime, rezultă că
De aici, conform [[Teorema chinezească a resturilor|teoremei chinezești a resturilor]], deoarece ''p'' și ''q'' sunt numere prime, rezultă că


:<math>m^{ed} \equiv m \pmod{pq}</math>
:<math>m^{ed} \equiv m \pmod{pq}</math>


==Performanţe în implementări==
== Performanțe în implementări ==


În general, deoarece se bazează pe o operaţie destul de costisitoare din punct de vedere al timpului de calcul şi al resurselor folosite, şi anume exponenţierea modulo ''n'', viteza RSA este mult mai mică decât a algoritmilor de criptare cu cheie secretă.<ref>Menezes, p. 291</ref> [[Bruce Schneier]] estima, pe baza unor calcule efectuate în [[anii 1990]], că o implementare hardware de RSA este de 1000 de ori mai lentă decât o implementare [[DES]], iar în software, RSA este de 100 de ori mai lent.
În general, deoarece se bazează pe o operație destul de costisitoare din punct de vedere al timpului de calcul și al resurselor folosite, și anume exponențierea modulo ''n'', viteza RSA este mult mai mică decât a algoritmilor de criptare cu cheie secretă.<ref>Menezes, p. 291</ref> [[Bruce Schneier]] estima, pe baza unor calcule efectuate în [[anii 1990]], că o implementare hardware de RSA este de 1000 de ori mai lentă decât o implementare [[DES]], iar în software, RSA este de 100 de ori mai lent.


Există anumite modificări care pot aduce performanţe sporite, precum alegerea unui exponent de criptare mic, care astfel reduce calculele necesare criptării, rezolvând în acelaşi timp şi unele probleme de securitate.<ref name="schneier389">Schneier, p. 389</ref> De asemenea, operaţiile cu cheia secretă pot fi accelerate pe baza [[Teorema chinezească a resturilor|teoremei chinezeşti a resturilor]], dacă se stochează ''p'', ''q'' şi unele rezultate intermediare, folosite des.<ref name="schneier389"/> Cu toate acestea, îmbunătăţirile nu sunt mari, iar ordinul de mărime al diferenţelor de performanţă faţă de implementările algoritmilor cu cheie secretă rămân aceleaşi. De aceea, în sistemele de comunicaţie în timp real, în care viteza de criptare şi decriptare este esenţială (cum ar fi, de exemplu, aplicaţiile de streaming video sau audio securizate), RSA se foloseşte doar la începutul comunicaţiei, pentru a transmite cheia secretă de comunicaţie, care ulterior este folosită într-un algoritm cu cheie secretă, cum ar fi [[3DES]] sau [[AES]].
Există anumite modificări care pot aduce performanțe sporite, precum alegerea unui exponent de criptare mic, care astfel reduce calculele necesare criptării, rezolvând în același timp și unele probleme de securitate.<ref name="schneier389">Schneier, p. 389</ref> De asemenea, operațiile cu cheia secretă pot fi accelerate pe baza [[Teorema chinezească a resturilor|teoremei chinezești a resturilor]], dacă se stochează ''p'', ''q'' și unele rezultate intermediare, folosite des.<ref name="schneier389"/> Cu toate acestea, îmbunătățirile nu sunt mari, iar ordinul de mărime al diferențelor de performanță față de implementările algoritmilor cu cheie secretă rămâne același. De aceea, în sistemele de comunicație în timp real, în care viteza de criptare și decriptare este esențială (cum ar fi, de exemplu, aplicațiile de streaming video sau audio securizate), RSA se folosește doar la începutul comunicației, pentru a transmite cheia secretă de comunicație, care ulterior este folosită într-un algoritm cu cheie secretă, cum ar fi [[3DES]] sau [[AES]].


==Securitatea==
== Securitatea ==
Problema decriptării unui mesaj criptat cu RSA este denumită ''problema RSA''. Aceasta constă în obţinerea radicalului de ordin ''e'' modulo ''n'', unde ''e'' şi ''n'' au proprietatea că ''n'' este produsul a două numere prime mari ''p'' şi ''q'', iar ''e'' este [[Numere prime între ele|prim cu]] produsul dintre ''p-1'' şi ''q-1''<ref>Menezes, 2005, p. 98</ref>. În acest moment, cea mai eficientă metodă de a realiza aceasta este [[Factorizarea întregilor|descompunerea în factori primi]] a lui ''n'', şi obţinerea astfel a cheii secrete ''d'' pe baza lui ''e''. Astfel, este demonstrat că dificultatea spargerii unui mesaj criptat cu RSA nu este mai dificilă decât problema factorizării. Nu a fost descoperită încă o altă soluţie generală a problemei RSA, dar nici nu s-a demonstrat matematic că nu există o altă soluţie<ref name="Schneier390">Schneier, p. 390</ref><ref>Menezes, 2005, p. 99</ref>.
Problema decriptării unui mesaj criptat cu RSA este denumită ''problema RSA''. Aceasta constă în obținerea radicalului de ordin ''e'' modulo ''n'', unde ''e'' și ''n'' au proprietatea că ''n'' este produsul a două numere prime mari ''p'' și ''q'', iar ''e'' este [[Numere prime între ele|prim cu]] produsul dintre ''p-1'' și ''q-1''.<ref>Menezes, 2005, p. 98</ref> În acest moment, cea mai eficientă metodă de a realiza aceasta este [[Factorizarea întregilor|descompunerea în factori primi]] a lui ''n'', și obținerea astfel a cheii secrete ''d'' pe baza lui ''e''. Astfel, este demonstrat că dificultatea spargerii unui mesaj criptat cu RSA nu este mai dificilă decât problema factorizării. Nu a fost descoperită încă o altă soluție generală a problemei RSA, dar nici nu s-a demonstrat matematic că nu există o altă soluție.<ref name="Schneier390">Schneier, p. 390</ref><ref>Menezes, 2005, p. 99</ref>


[[Imagine:Nfs graph.png|thumb|right|240px|Graficul complexităţii celei mai bune metode de factorizare a întregilor în funcţie de lungimea reprezentării binare a numărului factorizat. Se observă că această complexitate este exponenţială, crescând foarte mult pentru numere mari]]
[[Fișier:Nfs graph.png|thumb|right|240px|Graficul complexităţii celei mai bune metode de factorizare a întregilor în funcţie de lungimea reprezentării binare a numărului factorizat (pe abscisă, <code>log n</code>, adică numărul de cifre al numărului de factorizat; pe ordonată, ordinul de mărime al duratei de factorizare). Se observă că această complexitate este exponenţială, crescând foarte mult pentru numere mari]]
Factorizarea întregilor prin metodele comune ajută la găsirea soluţiilor în timp util doar pentru numere mici. Pentru numere mari, algoritmii de factorizare, cu complexitate exponenţială, dau soluţia după foarte mult timp. Cea mai rapidă metodă de factorizare a întregilor, algoritmul general al ciurului câmpurilor de numere, are o [[Complexitatea algoritmilor|complexitate]] de <math>o\left(e^{c((\log{n})^{\frac{1}{3}}(\log{\log{n}})^{\frac{2}{3}}}\right)</math><ref>Lenstra, p. 51</ref><ref name="nfs_wolfram">{{Citat web|author=Weisstein, Eric W.|title=Number Field Sieve|publisher=MathWorld--A Wolfram Web Resource|url=http://mathworld.wolfram.com/NumberFieldSieve.html}}</ref> Aici, ''c'' este un număr ce ia valori în jur de 1,9 pentru numere de tipul lui ''n'', adică numere cu doi factori primi. Cel mai mare număr factorizat vreodată prin acest algoritm, rulat în anul 2005, de către specialişti de la Agenţia Federală Germană pentru Securitatea Tehnologiei Informaţiei, are 200 de cifre zecimale, iar reprezentarea binară a factorilor primi obţinuţi ocupă 663 de biţi<ref>Stallings, p. 276</ref><ref>{{Citat web|title=RSA-200 Factored|url=http://mathworld.wolfram.com/news/2005-05-10/rsa-200/|author=Eric W. Weisstein|publisher=Mathworld news|date=[[10 mai]] [[2005]]}}</ref>. Cheile de criptare RSA cele mai sigure au lungimi de peste 1024 de biţi.
Factorizarea întregilor prin metodele comune ajută la găsirea soluțiilor în timp util doar pentru numere mici. Pentru numere mari, algoritmii de factorizare, cu complexitate exponențială, dau soluția după foarte mult timp. Cea mai rapidă metodă de factorizare a întregilor, algoritmul general al ciurului câmpurilor de numere, are o [[Complexitatea algoritmilor|complexitate]] de <math>o\left(e^{c((\log{n})^{\frac{1}{3}}(\log{\log{n}})^{\frac{2}{3}}}\right)</math><ref>Lenstra, p. 51</ref><ref name="nfs_wolfram">{{Citat web|author=Weisstein, Eric W.|title=Number Field Sieve|publisher=MathWorld--A Wolfram Web Resource|url=http://mathworld.wolfram.com/NumberFieldSieve.html}}</ref> Aici, ''c'' este un număr ce ia valori în jur de 1,9 pentru numere de tipul lui ''n'', adică numere cu doi factori primi. Cel mai mare număr factorizat vreodată prin acest algoritm, rulat în anul 2005, de către specialiști de la Agenția Federală Germană pentru Securitatea Tehnologiei Informației, are 200 de cifre zecimale, iar reprezentarea binară a factorilor primi obținuți ocupă 663 de biți.<ref>Stallings, p. 276</ref><ref>{{Citat web|title=RSA-200 Factored|url=http://mathworld.wolfram.com/news/2005-05-10/rsa-200/|author=Eric W. Weisstein|publisher=Mathworld news|date=[[10 mai]] [[2005]]}}</ref> Cheile de criptare RSA cele mai sigure au lungimi de peste 1024 de biți.


Atacul RSA prin metoda forţei brute, adică încercarea fiecărei chei secrete posibile, consumă chiar mai mult timp decât factorizarea<ref name="Schneier390"/>.
Atacul RSA prin metoda forței brute, adică încercarea fiecărei chei secrete posibile, consumă chiar mai mult timp decât factorizarea.<ref name="Schneier390"/>


===Atacuri împotriva RSA===
=== Atacuri împotriva RSA ===


Deşi securitatea algoritmului RSA constă în legătura dintre acesta şi [[factorizarea întregilor]], el trebuie folosit cu grijă în implementări, deoarece, în caz de folosire eronată, sistemele bazate pe RSA pot fi atacate în anumite maniere care ocolesc factorizarea efectivă a modulului, atacatorul ajungând să obţină mesajul clar sau cheia secretă.
Deși securitatea algoritmului RSA constă în legătura dintre acesta și [[factorizarea întregilor]], el trebuie folosit cu grijă în implementări, deoarece, în caz de folosire eronată, sistemele bazate pe RSA pot fi atacate în anumite maniere care ocolesc factorizarea efectivă a modulului, atacatorul ajungând să obțină mesajul clar sau cheia secretă.


====Atac cu text cifrat ales====
==== Atac cu text cifrat ales ====


În cazul atacului cu text cifrat ales, atacatorul dispune de cheia publică a entităţii atacate (exponentul de criptare ''e'' şi modulul ''n''), şi interceptează mesaje cifrate trimise acestuia. Pentru a obţine mesajul clar ''m'' dintr-un mesaj cifrat ''c'', atacatorul poate proceda, de exemplu, astfel<ref>Stallings, p. 280</ref>:
În cazul atacului cu text cifrat ales, atacatorul dispune de cheia publică a entității atacate (exponentul de criptare ''e'' și modulul ''n''), și interceptează mesaje cifrate trimise acestuia. Pentru a obține mesajul clar ''m'' dintr-un mesaj cifrat ''c'', atacatorul poate proceda, de exemplu, astfel:<ref>Stallings, p. 280</ref>


#Calculează <math>x = (c \times 2^e) \pmod{n}</math>
# Calculează <math>x = (c \times 2^e) \pmod{n}</math>
#Trimite entităţii atacate spre semnare pe ''x'', obţinând <math>y = x^d \pmod{n}</math>
# Trimite entității atacate spre semnare pe ''x'', obținând <math>y = x^d \pmod{n}</math>
#Se observă că <math>x = c \times 2^e \pmod{n} = m^e \times 2^e \pmod{n} = (2m)^e \pmod{n}</math>
# Se observă că <math>x = c \times 2^e \pmod{n} = m^e \times 2^e \pmod{n} = (2m)^e \pmod{n}</math>
#Se rezolvă ecuaţia <math>y = (2m) \pmod{n}</math>
# Se rezolvă ecuația <math>y = (2m) \pmod{n}</math>


Atacatorul obţine astfel mesajul cifrat. Există mai multe feluri de atacuri cifrate,<ref>Mai multe exemple sunt descrise în Schneier, pp 390-391</ref> dar sunt câteva moduri de apărare împotriva lor. Unele pot fi evitate dacă pur şi simplu entitatea protejată cu chei secrete refuză să semneze texte arbitrare trimise de terţi.<ref>Schneier, p. 391</ref> Dacă acest lucru nu este posibil (ca de exemplu în cazul unui notar public care trebuie să semneze documente electronice prezentate de persoane străine), atunci atacul poate fi prevenit prin folosirea unei perechi diferite de chei pentru criptare şi pentru semnătura electronică. De asemenea, este necesar să se folosească şi un padding aleator pentru mesaj înainte de criptare sau, în cazul semnăturii, să nu se semneze mesajul clar, ci un [[Funcţie hash|hash]] al acestuia. De asemenea, atacul poate fi evitat şi dacă se impune o anumită structură predefinită mesajelor primite spre semnare.<ref>Menezes, p. 289</ref>
Atacatorul obține astfel mesajul cifrat. Există mai multe feluri de atacuri cifrate,<ref>Mai multe exemple sunt descrise în Schneier, pp 390-391</ref> dar sunt câteva moduri de apărare împotriva lor. Unele pot fi evitate dacă pur și simplu entitatea protejată cu chei secrete refuză să semneze texte arbitrare trimise de terți.<ref>Schneier, p. 391</ref> Dacă acest lucru nu este posibil (ca de exemplu în cazul unui notar public care trebuie să semneze documente electronice prezentate de persoane străine), atunci atacul poate fi prevenit prin folosirea unei perechi diferite de chei pentru criptare și pentru semnătura electronică. De asemenea, este necesar să se folosească și un padding aleator pentru mesaj înainte de criptare sau, în cazul semnăturii, să nu se semneze mesajul clar, ci un [[Funcție hash|hash]] al acestuia. De asemenea, atacul poate fi evitat și dacă se impune o anumită structură predefinită mesajelor primite spre semnare.<ref>Menezes, p. 289</ref>


====Mesaje necriptate====
==== Mesaje necriptate ====
Întrucât RSA se bazează pe ridicarea la putere (modulo un număr ''n''), există anumite părţi de mesaje care nu sunt criptate, părţi rezultate în urma împărţirii mesajului pe blocuri. Astfel de mesaje sunt mesajele ''m'' cu proprietatea că ''m''=''m<sup>x</sup>'' (mod ''n'') oricare ar fi ''x'', ca de exemplu ''m''=0, ''m''=1, ''m''=''n''-1. Numărul exact al acestor mesaje decriptate este <math>(1+cmmdc(e-1,p-1)) \cdot (1+cmmdc(e-1,q-1))</math><ref>Menezes, p. 290</ref>, şi deci este de minim 9 (deoarece ''e'', ''p'' şi ''q'' sunt impare). Pentru a micşora numărul de astfel de părţi de mesaj, este util să se folosească un exponent public ''e'' cât mai mic.
Întrucât RSA se bazează pe ridicarea la putere (modulo un număr ''n''), există anumite părți de mesaje care nu sunt criptate, părți rezultate în urma împărțirii mesajului pe blocuri. Astfel de mesaje sunt mesajele ''m'' cu proprietatea că ''m''=''m<sup>x</sup>'' (mod ''n'') oricare ar fi ''x'', ca de exemplu ''m''=0, ''m''=1, ''m''=''n''-1. Numărul exact al acestor mesaje decriptate este <math>(1+cmmdc(e-1,p-1)) \cdot (1+cmmdc(e-1,q-1))</math><ref>Menezes, p. 290</ref>, și deci este de minim 9 (deoarece ''e'', ''p'' și ''q'' sunt impare). Pentru a micșora numărul de astfel de părți de mesaj, este util să se folosească un exponent public ''e'' cât mai mic.


====Exponentul de criptare mic====
==== Exponentul de criptare mic ====
În unele aplicaţii, se foloseşte un exponent de criptare (public) mic, de exemplu 3, pentru a mări performanţa, dar şi pentru a rezolva unele probleme de securitate. Dacă mai multe entităţi care comunică folosesc acelaşi exponent public (dar fiecare are propriul modul şi deci propria cheie secretă), atunci acelaşi mesaj trimis mai multor destinatari are următoarele valori:
În unele aplicații, se folosește un exponent de criptare (public) mic, de exemplu 3, pentru a mări performanța, dar și pentru a rezolva unele probleme de securitate. Dacă mai multe entități care comunică folosesc același exponent public (dar fiecare are propriul modul și deci propria cheie secretă), atunci același mesaj trimis mai multor destinatari are următoarele valori:


:<math>c_1 = m^e \pmod{n_1}</math>
:<math>c_1 = m^e \pmod{n_1}</math>
Linia 90: Linia 91:
:<math>c_3 = m^e \pmod{n_3}</math>
:<math>c_3 = m^e \pmod{n_3}</math>


unde ''n<sub>i</sub>'' sunt modulele celor trei destinatari, ''e'' este exponentul comun acestora iar ''m'' este mesajul trimis tuturor celor trei. Un atacator poate folosi [[algoritmul lui Gauss]] pentru a descoperi o soluţie mai mică decât ''n<sub>1</sub>n<sub>2</sub>n<sub>3</sub>'' a unui sistem compus din următoarele ecuaţii:
unde ''n<sub>i</sub>'' sunt modulele celor trei destinatari, ''e'' este exponentul comun acestora iar ''m'' este mesajul trimis tuturor celor trei. Un atacator poate folosi [[algoritmul lui Gauss]] pentru a descoperi o soluție mai mică decât ''n<sub>1</sub>n<sub>2</sub>n<sub>3</sub>'' a unui sistem compus din următoarele ecuații:


:<math>x = m^e \pmod{n_1}</math>
:<math>x = m^e \pmod{n_1}</math>
Linia 96: Linia 97:
:<math>x = m^e \pmod{n_3}</math>
:<math>x = m^e \pmod{n_3}</math>


Această soluţie este, conform [[Teorema chinezească a resturilor|teoremei chinezeşti a resturilor]], cubul mesajului ''m''.<ref>Menezes, p. 288</ref> Soluţia pentru această problemă este cea denumită ''sărarea'' mesajului (din {{en|salting}}), adică adăugarea unui padding format din numere pseudoaleatoare, padding diferit pentru fiecare expediere a mesajului.
Această soluție este, conform [[Teorema chinezească a resturilor|teoremei chinezești a resturilor]], cubul mesajului ''m''.<ref>Menezes, p. 288</ref> Soluția pentru această problemă este cea denumită ''sărarea'' mesajului (din {{en|salting}}), adică adăugarea unui padding format din numere pseudoaleatoare, padding diferit pentru fiecare expediere a mesajului.


====Exponentul de decriptare mic====
==== Exponentul de decriptare mic ====
Dacă exponentul de decriptare (cel secret) este mic, pe lângă faptul că multe părţi din mesaj nu se criptează, aşa cum s-a arătat mai sus, există un algoritm rapid de găsire a lui ''d'', cunoscând informaţiile ''e'' şi ''n''.<ref name="Menezes288">Menezes, p. 288</ref> Acest algoritm nu este eficient dacă ''d'' este de acelaşi ordin de mărime cu ''n'', deci dacă ''e'' este mic<ref name="Menezes288"/>, acesta fiind unul din motivele pentru care se alege în general ''e'' un număr mic, pentru ca ''d'' să fie cât mai mare.
Dacă exponentul de decriptare (cel secret) este mic, pe lângă faptul că multe părți din mesaj nu se criptează, așa cum s-a arătat mai sus, există un algoritm rapid de găsire a lui ''d'', cunoscând informațiile ''e'' și ''n''.<ref name="Menezes288">Menezes, p. 288</ref> Acest algoritm nu este eficient dacă ''d'' este de același ordin de mărime cu ''n'', deci dacă ''e'' este mic<ref name="Menezes288"/>, acesta fiind unul din motivele pentru care se alege în general ''e'' un număr mic, pentru ca ''d'' să fie cât mai mare.


==Note==
== Note ==
{{Reflist|2}}
{{listănote|2}}


==Bibliografie==
== Bibliografie ==
* {{Citat carte|title=Applied Cryptography, Second Edition: Protocols, Algorithms, and Source Code in C|author=Bruce Schneier|publisher=Wiley Computer Publishing, John Wiley & Sons, Inc.|year=1996|isbn=0471128457}}
* {{Citat carte|title=Applied Cryptography, Second Edition: Protocols, Algorithms, and Source Code in C|author=Bruce Schneier|publisher=Wiley Computer Publishing, John Wiley & Sons, Inc.|year=1996|isbn=0471128457}}
* {{Citat carte|title=Cryptography and Network Security, 4th edition|publisher=Prentice Hall|author=William Stallings|year=2005|isbn=0-13-187319-3}}
* {{Citat carte|title=Cryptography and Network Security, 4th edition|publisher=Prentice Hall|author=William Stallings|year=2005|isbn=0-13-187319-3}}
* {{Citat carte|title=Handbook of Applied Cryptography|author=Alfred Menezes|others=Paul van Oorschot, Scott Vanstone}}
* {{Citat carte|title=Handbook of Applied Cryptography|author=Alfred Menezes|others=Paul van Oorschot, Scott Vanstone}}
* {{Citat carte|url=http://books.google.ro/books?id=_QBvFRP69xEC&pg=PA52&lpg=PA52&dq=number+field+sieve+complexity&source=web&ots=NL6WwNclMl&sig=Hyv-vLMJNh3hCzRFPPb-5OTKkdc&hl=ro#PPA51,M1|author=A. W. Lenstra, H.W. Lenstra Jr.|title=The development of the number field sieve|publisher=Springer|date=1993}}
* {{Citat carte|url=http://books.google.ro/books?id=_QBvFRP69xEC&pg=PA52&lpg=PA52&dq=number+field+sieve+complexity&source=web&ots=NL6WwNclMl&sig=Hyv-vLMJNh3hCzRFPPb-5OTKkdc&hl=ro#PPA51,M1|author=A. W. Lenstra, H.W. Lenstra Jr.|title=The development of the number field sieve|publisher=Springer|date=1993}}
* {{Citat web|url=http://people.csail.mit.edu/rivest/Rsapaper.pdf|title=A Method for Obtaining Digital Signatures and Public-Key Cryptosystems|author=Rivest, R.L.; Shamir, A.; Adleman, L.|accessdate=30 martie 2009|archive-date=2008-12-17|archive-url=https://web.archive.org/web/20081217101831/http://people.csail.mit.edu/rivest/Rsapaper.pdf|dead-url=yes}}


[[Categorie:Criptografie]]
[[Categorie:Criptografie]]
[[Categorie:Criptosisteme cu cheie asimetrică]]
[[Categorie:Criptosisteme cu cheie asimetrică]]

[[ar:خوارزمية آر إس إيه]]
[[bg:RSA]]
[[ca:RSA]]
[[cs:RSA]]
[[da:RSA]]
[[de:RSA-Kryptosystem]]
[[el:RSA]]
[[en:RSA]]
[[eo:RSA]]
[[es:RSA]]
[[et:RSA]]
[[eu:RSA]]
[[fa:آراس‌ای]]
[[fi:RSA]]
[[fr:Rivest Shamir Adleman]]
[[gl:RSA]]
[[he:RSA]]
[[hr:RSA]]
[[hu:RSA-eljárás]]
[[id:RSA]]
[[is:RSA]]
[[it:RSA]]
[[ja:RSA暗号]]
[[ka:RSA ალგორითმი]]
[[ko:RSA 암호]]
[[lt:RSA]]
[[lv:RSA šifrēšanas algoritms]]
[[nl:RSA (cryptografie)]]
[[no:RSA]]
[[pl:RSA (kryptografia)]]
[[pt:RSA]]
[[ru:RSA]]
[[simple:RSA]]
[[sl:RSA]]
[[sr:RSA]]
[[sv:RSA]]
[[th:RSA]]
[[tr:RSA]]
[[uk:RSA]]
[[vi:RSA (mã hóa)]]
[[zh:RSA加密演算法]]

Versiunea curentă din 9 septembrie 2023 16:34

Pentru Republica Sud-Africană, vedeți Africa de Sud.

În criptografie, RSA este un algoritm criptografic cu chei publice, primul algoritm utilizat atât pentru criptare, cât și pentru semnătura electronică. Algoritmul a fost dezvoltat în 1977 și publicat în 1978 de Ron Rivest, Adi Shamir și Leonard Adleman la MIT și își trage numele de la inițialele numelor celor trei autori.[1]

Puterea sa criptografică se bazează pe dificultatea problemei factorizării numerelor întregi, problemă la care se reduce criptanaliza RSA și pentru care toți algoritmii de rezolvare cunoscuți au complexitate exponențială. Există însă câteva metode de criptanaliză care ocolesc factorizarea efectivă, exploatând maniere eronate de implementare efectivă a schemei de criptare.

RSA este un algoritm de criptare pe blocuri. Aceasta înseamnă că atât textul clar cât și cel cifrat sunt numere între 0 și n-1, cu un n ales. Un mesaj de dimensiune mai mare decât este împărțit în segmente de lungime corespunzătoare, numite blocuri, care sunt cifrate rând pe rând.[2] De asemenea, ca algoritm criptografic cu chei publice, funcționează pe baza unei perechi de chei legate matematic între ele: o cheie publică, cunoscută de toată lumea, și una secretă, cunoscută doar de deținătorul acesteia.

Generarea cheilor

[modificare | modificare sursă]

Perechea de chei se generează după următorii pași[3]:

  1. Se generează două numere prime, de preferat mari, p și q;
  2. Se calculează și
  3. Se alege un întreg aleator e, astfel încât cmmdc(e, φ) = 1. Perechea (n, e) este cheia publică.
  4. Folosind algoritmul lui Euclid extins, se calculează întregul d, unicul cu proprietatea că . (n, d) constituie cheia secretă.

Decizia cu privire la care dintre e și d este cheia publică și care este cea secretă este, din punct de vedere matematic, arbitrară, oricare dintre cele două numere poate juca oricare dintre roluri[4]. În practică însă, pentru a mări viteza de criptare, și întrucât dintre cele două numere e este cel ales arbitrar, e este cheia publică iar valoarea sa este aleasă un număr mic, de regulă 3, 17 sau 65537 (216+1)[5]. Aceasta conduce la un număr minim de înmulțiri, deci la o performanță sporită, deoarece toate aceste numere au doar două cifre 1 în reprezentarea lor binară[5].

Criptarea și decriptarea

[modificare | modificare sursă]

Presupunând că mesajul clar este sub forma unui număr m, mai mic decât n, atunci mesajul cifrat, notat cu c este

unde e este cheia publică a destinatarului mesajului. Pentru a decripta mesajul, destinatarul își folosește cheia sa secretă d, care are proprietatea foarte importantă că:

Astfel, mesajul clar este recuperat calculând:

Oricine poate cripta mesaje cu cheia publică a destinatarului, dar numai acesta din urmă poate decripta, deoarece trebuie să folosească cheia sa secretă.

Algoritmul poate fi folosit și pentru semnătura electronică, folosind cheile invers. Dacă o entitate criptează un mesaj (sau mai degrabă un hash al acestuia) cu cheia sa secretă și atașează rezultatul mesajului său, atunci oricine poate verifica, decriptând cu cheia publică a semnatarului și comparând rezultatul cu mesajul clar (sau cu hash-ul acestuia), că într-adevăr acea entitate este autorul mesajului.

Demonstrația formulei de decriptare

[modificare | modificare sursă]

Formula de decriptare este valabilă, deoarece[6]:

și, fiindcă , atunci
și

și deci se poate scrie:

Dar, cum p este prim, și deci prim cu m, conform micii teoreme a lui Fermat, rezultă că

Astfel,

.

Dacă p nu este totuși prim cu m, atunci înseamnă că m este multiplu al lui p, caz trivial în care m este congruent cu 0 modulo p, și deci ridicat la orice putere este congruent cu 0 și deci cu el însuși.

Analog și pentru q,

De aici, conform teoremei chinezești a resturilor, deoarece p și q sunt numere prime, rezultă că

Performanțe în implementări

[modificare | modificare sursă]

În general, deoarece se bazează pe o operație destul de costisitoare din punct de vedere al timpului de calcul și al resurselor folosite, și anume exponențierea modulo n, viteza RSA este mult mai mică decât a algoritmilor de criptare cu cheie secretă.[7] Bruce Schneier estima, pe baza unor calcule efectuate în anii 1990, că o implementare hardware de RSA este de 1000 de ori mai lentă decât o implementare DES, iar în software, RSA este de 100 de ori mai lent.

Există anumite modificări care pot aduce performanțe sporite, precum alegerea unui exponent de criptare mic, care astfel reduce calculele necesare criptării, rezolvând în același timp și unele probleme de securitate.[8] De asemenea, operațiile cu cheia secretă pot fi accelerate pe baza teoremei chinezești a resturilor, dacă se stochează p, q și unele rezultate intermediare, folosite des.[8] Cu toate acestea, îmbunătățirile nu sunt mari, iar ordinul de mărime al diferențelor de performanță față de implementările algoritmilor cu cheie secretă rămâne același. De aceea, în sistemele de comunicație în timp real, în care viteza de criptare și decriptare este esențială (cum ar fi, de exemplu, aplicațiile de streaming video sau audio securizate), RSA se folosește doar la începutul comunicației, pentru a transmite cheia secretă de comunicație, care ulterior este folosită într-un algoritm cu cheie secretă, cum ar fi 3DES sau AES.

Problema decriptării unui mesaj criptat cu RSA este denumită problema RSA. Aceasta constă în obținerea radicalului de ordin e modulo n, unde e și n au proprietatea că n este produsul a două numere prime mari p și q, iar e este prim cu produsul dintre p-1 și q-1.[9] În acest moment, cea mai eficientă metodă de a realiza aceasta este descompunerea în factori primi a lui n, și obținerea astfel a cheii secrete d pe baza lui e. Astfel, este demonstrat că dificultatea spargerii unui mesaj criptat cu RSA nu este mai dificilă decât problema factorizării. Nu a fost descoperită încă o altă soluție generală a problemei RSA, dar nici nu s-a demonstrat matematic că nu există o altă soluție.[10][11]

Graficul complexităţii celei mai bune metode de factorizare a întregilor în funcţie de lungimea reprezentării binare a numărului factorizat (pe abscisă, log n, adică numărul de cifre al numărului de factorizat; pe ordonată, ordinul de mărime al duratei de factorizare). Se observă că această complexitate este exponenţială, crescând foarte mult pentru numere mari

Factorizarea întregilor prin metodele comune ajută la găsirea soluțiilor în timp util doar pentru numere mici. Pentru numere mari, algoritmii de factorizare, cu complexitate exponențială, dau soluția după foarte mult timp. Cea mai rapidă metodă de factorizare a întregilor, algoritmul general al ciurului câmpurilor de numere, are o complexitate de [12][13] Aici, c este un număr ce ia valori în jur de 1,9 pentru numere de tipul lui n, adică numere cu doi factori primi. Cel mai mare număr factorizat vreodată prin acest algoritm, rulat în anul 2005, de către specialiști de la Agenția Federală Germană pentru Securitatea Tehnologiei Informației, are 200 de cifre zecimale, iar reprezentarea binară a factorilor primi obținuți ocupă 663 de biți.[14][15] Cheile de criptare RSA cele mai sigure au lungimi de peste 1024 de biți.

Atacul RSA prin metoda forței brute, adică încercarea fiecărei chei secrete posibile, consumă chiar mai mult timp decât factorizarea.[10]

Atacuri împotriva RSA

[modificare | modificare sursă]

Deși securitatea algoritmului RSA constă în legătura dintre acesta și factorizarea întregilor, el trebuie folosit cu grijă în implementări, deoarece, în caz de folosire eronată, sistemele bazate pe RSA pot fi atacate în anumite maniere care ocolesc factorizarea efectivă a modulului, atacatorul ajungând să obțină mesajul clar sau cheia secretă.

Atac cu text cifrat ales

[modificare | modificare sursă]

În cazul atacului cu text cifrat ales, atacatorul dispune de cheia publică a entității atacate (exponentul de criptare e și modulul n), și interceptează mesaje cifrate trimise acestuia. Pentru a obține mesajul clar m dintr-un mesaj cifrat c, atacatorul poate proceda, de exemplu, astfel:[16]

  1. Calculează
  2. Trimite entității atacate spre semnare pe x, obținând
  3. Se observă că
  4. Se rezolvă ecuația

Atacatorul obține astfel mesajul cifrat. Există mai multe feluri de atacuri cifrate,[17] dar sunt câteva moduri de apărare împotriva lor. Unele pot fi evitate dacă pur și simplu entitatea protejată cu chei secrete refuză să semneze texte arbitrare trimise de terți.[18] Dacă acest lucru nu este posibil (ca de exemplu în cazul unui notar public care trebuie să semneze documente electronice prezentate de persoane străine), atunci atacul poate fi prevenit prin folosirea unei perechi diferite de chei pentru criptare și pentru semnătura electronică. De asemenea, este necesar să se folosească și un padding aleator pentru mesaj înainte de criptare sau, în cazul semnăturii, să nu se semneze mesajul clar, ci un hash al acestuia. De asemenea, atacul poate fi evitat și dacă se impune o anumită structură predefinită mesajelor primite spre semnare.[19]

Mesaje necriptate

[modificare | modificare sursă]

Întrucât RSA se bazează pe ridicarea la putere (modulo un număr n), există anumite părți de mesaje care nu sunt criptate, părți rezultate în urma împărțirii mesajului pe blocuri. Astfel de mesaje sunt mesajele m cu proprietatea că m=mx (mod n) oricare ar fi x, ca de exemplu m=0, m=1, m=n-1. Numărul exact al acestor mesaje decriptate este [20], și deci este de minim 9 (deoarece e, p și q sunt impare). Pentru a micșora numărul de astfel de părți de mesaj, este util să se folosească un exponent public e cât mai mic.

Exponentul de criptare mic

[modificare | modificare sursă]

În unele aplicații, se folosește un exponent de criptare (public) mic, de exemplu 3, pentru a mări performanța, dar și pentru a rezolva unele probleme de securitate. Dacă mai multe entități care comunică folosesc același exponent public (dar fiecare are propriul modul și deci propria cheie secretă), atunci același mesaj trimis mai multor destinatari are următoarele valori:

unde ni sunt modulele celor trei destinatari, e este exponentul comun acestora iar m este mesajul trimis tuturor celor trei. Un atacator poate folosi algoritmul lui Gauss pentru a descoperi o soluție mai mică decât n1n2n3 a unui sistem compus din următoarele ecuații:

Această soluție este, conform teoremei chinezești a resturilor, cubul mesajului m.[21] Soluția pentru această problemă este cea denumită sărarea mesajului (din engleză salting), adică adăugarea unui padding format din numere pseudoaleatoare, padding diferit pentru fiecare expediere a mesajului.

Exponentul de decriptare mic

[modificare | modificare sursă]

Dacă exponentul de decriptare (cel secret) este mic, pe lângă faptul că multe părți din mesaj nu se criptează, așa cum s-a arătat mai sus, există un algoritm rapid de găsire a lui d, cunoscând informațiile e și n.[22] Acest algoritm nu este eficient dacă d este de același ordin de mărime cu n, deci dacă e este mic[22], acesta fiind unul din motivele pentru care se alege în general e un număr mic, pentru ca d să fie cât mai mare.

  1. ^ Schneier, 1996, p. 385
  2. ^ Stallings, 2005, p. 269
  3. ^ Menezes, p. 286
  4. ^ Schneier, 1996, p. 387
  5. ^ a b Stallings, 2005, p. 274
  6. ^ Demonstrație similară cu cea din Menezes, p. 286
  7. ^ Menezes, p. 291
  8. ^ a b Schneier, p. 389
  9. ^ Menezes, 2005, p. 98
  10. ^ a b Schneier, p. 390
  11. ^ Menezes, 2005, p. 99
  12. ^ Lenstra, p. 51
  13. ^ Weisstein, Eric W. „Number Field Sieve”. MathWorld--A Wolfram Web Resource. 
  14. ^ Stallings, p. 276
  15. ^ Eric W. Weisstein (10 mai 2005). „RSA-200 Factored”. Mathworld news.  Verificați datele pentru: |date= (ajutor)
  16. ^ Stallings, p. 280
  17. ^ Mai multe exemple sunt descrise în Schneier, pp 390-391
  18. ^ Schneier, p. 391
  19. ^ Menezes, p. 289
  20. ^ Menezes, p. 290
  21. ^ Menezes, p. 288
  22. ^ a b Menezes, p. 288