RSA

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.

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 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

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

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

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

Î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.

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 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

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

Î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

Î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

Î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

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.

Note

  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

Bibliografie

Read other articles:

Layout of United States vehicle license plates Main article: Vehicle registration plates of the United States This article needs to be updated. Please help update this article to reflect recent events or newly available information. (June 2022) In the United States, the appearance of license plates is frequently chosen to contain symbols, colors, or slogans associated with the issuing jurisdiction, which are the 50 U.S. states, the District of Columbia, the five inhabited U.S. territories, an...

 

United States historic placeAlice Paul BirthplaceU.S. National Register of Historic PlacesU.S. National Historic LandmarkNew Jersey Register of Historic Places Paulsdale, c. 1958, with Hooton Road in the backgroundShow map of Burlington County, New JerseyShow map of New JerseyShow map of the United StatesLocation128 Hooton RoadMount Laurel Township, New Jersey 08054Coordinates39°57′24″N 74°55′50.5″W / 39.95667°N 74.930694°W / 39.95667; -74.930694Area6.5 acr...

 

هذه المقالة يتيمة إذ تصل إليها مقالات أخرى قليلة جدًا. فضلًا، ساعد بإضافة وصلة إليها في مقالات متعلقة بها. (أبريل 2019) جيري هولاند معلومات شخصية الميلاد 23 فبراير 1955  بروكتون  الوفاة 16 يوليو 2009 (54 سنة)   مواطنة كندا  الحياة العملية المهنة موسيقي،  وعازف كمان  [لغ

1917–18/1918–21 state in Eastern Europe Not to be confused with Ukrainian People's Republic of Soviets or West Ukrainian People's Republic. Ukrainian People's RepublicУкраїнська Народня Республіка (Ukrainian)Ukrainska Narodnia Respublika1917–1918; 1918–1921[a] Flag Coat of arms Anthem: Ще не вмерла УкраїниShche ne vmerla UkrainyUkraine has not yet perishedState seal:The Ukrainian People's Republic (green) in 1918 superimpos...

 

A Igreja Católica Apostólica Romana no Canadá é composta por dezoito províncias eclesiásticas lideradas por arcebispos. As províncias estão divididas em 18 arquidioceses e 52 dioceses. [1][2] Lista de Dioceses Província eclesiástica de Edmonton A província é constituída geograficamente pela maior parte de Alberta, exceto pelo canto noroeste da província. Arquidiocese de Edmonton Diocese de Calgary Diocese de Saint Paul Província eclesiástica de Gatineau A província é constit...

 

Gubernur Jawa BaratPetahanaBey MachmudinPenjabatsejak 5 September 2023Pemerintah Provinsi Jawa BaratKediamanGedung Pakuan, Kota BandungMasa jabatan5 tahun; dapat diperpanjang sekaliPejabat perdanaSutardjo KertohadikusumoDibentuk19 Agustus 1945; 78 tahun lalu (1945-08-19)WakilWakil Gubernur Jawa BaratSitus webjabarprov.go.id Gubernur Jawa Barat adalah kepala pemerintah Jawa Barat. Ia bertugas memegang pemerintahan bersama dengan wakilnya dan para anggota Dewan Perwakilan Rakyat Daera...

Halaman ini berisi artikel tentang istilah geometri. Untuk penggunaan lain, lihat Dihedral. Jenis sudut Sudut 2D Siku-siku Interior Eksterior Pasangan sudut 2D Damping Vertikal Sudut komplementer Sudut suplemen Transversal Sudut 3D Dihedral lbs Sudut antara dua bidang (α, β, hijau) dalam suatu bidang ketiga (merah muda) yang memotong garis persimpangan di sudut kanan Sudut dihedral adalah sudut antara dua bidang yang berpotongan. Dalam kimia sudut dihedral adalah sudut antara bidang melalui...

 

This article does not cite any sources. Please help improve this article by adding citations to reliable sources. Unsourced material may be challenged and removed.Find sources: Bruce Coville's Book of Monsters – news · newspapers · books · scholar · JSTOR (July 2015) (Learn how and when to remove this template message) Bruce Coville's Book of MonstersFirst editionAuthorBruce CovilleJane YolenDebra DoyleJames D. MacdonaldSharon WebbJoe R. LansdaleJack P...

 

Bali United FCNama lengkapBali United Football ClubJulukanSerdadu TridatuBerdiri 1989 sebagai Putra Samarinda 2003, sebagai Persisam Putra Samarinda 15 Februari 2015 sebagai Bali United FC StadionStadion Kapten I Wayan Dipta(Kapasitas: 15.860[1])PemilikPieter Tanuri[2](40.96%)PT Asuransi Central Asia(8,88%)Ayu Patricia Rachmat(5,08%)Publik[3](IDX: BOLA)(45,08%)CEO Yabes TanuriManajer Michael Immanuel GeraldPelatih Stefano TecoAsisten Pelatih Stefan KeeltjesLigaLiga 12022

Coordenadas: 46° 32' N 23° 45' E Mihai Viteazu    Comuna   Localização País Romênia Região histórica Transilvânia Distrito Cluj Características geográficas Área total 47,53 km² População total (2007) 5 777 hab. Densidade 121,5 hab./km² Mihai Viteazu é uma comuna romena localizada no distrito de Cluj, na região histórica da Transilvânia. A comuna possui uma área de 47.53 km² e sua população era de 5777 habitantes segundo o...

 

مدرسة السير ونستون تشرشل الثانويةمعلومات عامةالبداية 1956 سُمِّي باسم ونستون تشرشل البلد كندا تقع في التقسيم الإداري كولومبيا البريطانية الإحداثيات 49°13′15″N 123°07′26″W / 49.2208°N 123.124°W / 49.2208; -123.124 موقع الويب churchill.vsb.bc.ca تعديل - تعديل مصدري - تعديل ويكي بيانات مدرسة ا...

 

南スーダンの国旗 各年の南スーダンの一覧(かくねんのみなみスーダンのいちらん)は、南スーダンの各年ごとの記事の一覧。この一覧では南スーダンの各年ごとの記事の他、各世紀と各年代、南スーダンの各分野における各年ごとの記事についても取り扱う。 一覧 21世紀 2010年代 2011年の南スーダン(英語版) 2012年の南スーダン(英語版) 2014年の南スーダン(英語...

889 Naval Air SquadronActive1942-1944 1945CountryUnited KingdomBranchRoyal NavyPart ofFleet Air ArmMilitary unit 889 Naval Air Squadron (889 NAS) was a Naval Air Squadron of the Royal Navy's Fleet Air Arm.[1] References ^ 889 Squadron. Fleet Air Arm Archive. Archived from the original on 24 September 2015. Retrieved 12 December 2014.{{cite web}}: CS1 maint: unfit URL (link) vte Royal Navy Fleet Air Arm aircraft squadronsActiveFlying 700X 703 705 727 744 750 814 815 820 824 825 84...

 

Iranian in ThailandKhaek Ma-ngon, Khaek Mahon, Khaek ChaosenRegions with significant populationsBangkokLanguagesThaiReligionTheravada Buddhism, minority Shia Islamhistorically Zoroastrianism[1] and Judaism Iranian migration to Thailand (Persian: مهاجرات ایرانیان به تایلند, romanized: Mohājerat-e Irāniyān be Tāyland) began as early as the 17th century. Thai citizens of Iranian background or descent may be called in Thai: Khaek Ma-ngon (Thai: แขกม...

 

Mountain range in Germany Elbe Sandstone MountainsLilienstein, one of several small mesas in the Saxon part of the Elbe Sandstone MountainsHighest pointPeakDěčínský SněžníkElevation723 m (2,372 ft)Coordinates50°47′44″N 14°6′25″E / 50.79556°N 14.10694°E / 50.79556; 14.10694GeographyElbe Sandstone MountainsShow map of Czech RepublicElbe Sandstone MountainsShow map of GermanyElbe Sandstone MountainsShow map of SaxonyElbe Sandstone Mountai...

The Church of Jesus Christ of Latter-day Saints in the Isle of ManLDS Church Building in DouglasAreaEurope NorthMembers281 (2022)[1]Wards1 Douglas Wardclass=notpageimage| Meetinghouse in the Isle of ManPurple = Meetinghouse The Church of Jesus Christ of Latter-day Saints in the Isle of Man refers to the Church of Jesus Christ of Latter-day Saints (LDS Church) and its members in the Isle of Man. As of 31 December 2022, The Church of Jesus Christ of Latter-day Saints reported 281 member...

 

Фотокамера «Зенит» з об'єктивом «Индустар-22» Зени́т — малоформатний однооб'єктивний дзеркальний фотоапарат з ручною установкою експозиції. Перший фотоапарат, який розроблений на Красногорському механічному заводі (КМЗ) який випускався серійно під маркою «Зенит» в 1...

 

Alex AlbonAlex di Indianapolis Motor Speedway, 2021LahirAlexander Albon Ansusinha23 Maret 1996 (umur 27)London, Inggris, Britania RayaKarier Kejuaraan Dunia Formula SatuKebangsaan ThailandTim 2023Williams-MercedesNomor mobil23Jumlah lomba82 (81 start)Juara dunia0Menang0Podium2Total poin228 poinPosisi pole0Lap tercepat0Lomba pertamaGrand Prix Australia 2019Lomba terakhirGrand Prix Abu Dhabi 2023Situs webSitus web resmiAjang sebelumnya20212017-2018201620152012–20142013–20142012Deutsche...

City district in Kuopio, Finland Puijo's Pesäpallo Stadium Puijo is a district of Kuopio, Finland. It is located north of the center of Kuopio, along the European route E63. The area includes, among other things, Puijo Hill with its nature reserves, and the Great Cemetery of Kuopio on the south side of the hill between the five roads and the railroad track. There are many exercise and sports venues in the district.[1] Right at the northern end of Sokos Hotel Puijonsarvi,[2] t...

 

Эта статья содержит информацию о запланированном или ожидаемом телесериале. Содержание может меняться коренным образом по мере приближения даты выхода сериала и появления новой информации. Добро пожаловать в Дерриангл. Welcome to Derry Скриншот из промо-ролика Max (посвящён...

 

Strategi Solo vs Squad di Free Fire: Cara Menang Mudah!