Kryptograficky bezpečný generátor pseudonáhodných čísel - Cryptographically secure pseudorandom number generator
A kryptograficky bezpečný generátor pseudonáhodných čísel (CSPRNG) nebo kryptografický generátor pseudonáhodných čísel (CPRNG)[1] je generátor pseudonáhodných čísel (PRNG) s vlastnostmi, díky nimž je vhodný pro použití v kryptografie. To je také volně známé jako kryptografický generátor náhodných čísel (CRNG) (viz Generování náhodných čísel § „True“ vs. pseudonáhodná čísla ).[2][3]
Většina kryptografické aplikace vyžadovat náhodný čísla, například:
- generace klíčů
- nonces
- soli v určitých podpisových schématech, včetně ECDSA, RSASSA-PSS
„Kvalita“ náhodnosti požadovaná pro tyto aplikace se liší. Například vytvoření a nonce v některých protokoly potřebuje pouze jedinečnost. Na druhé straně generace mistra klíč vyžaduje vyšší kvalitu, například více entropie. A v případě jednorázové podložky, informační teoretik záruka dokonalého utajení platí pouze v případě, že klíčový materiál pochází ze skutečného náhodného zdroje s vysokou entropií, a tedy jakýkoli druh generátoru pseudonáhodných čísel je nedostatečný.
V ideálním případě generování náhodných čísel v CSPRNG využívá entropii získanou z vysoce kvalitního zdroje, obecně API náhodnosti operačního systému. V několika takových zdánlivě nezávislých procesech však byly nalezeny neočekávané korelace. Z informačního teoretického hlediska je míra náhodnosti, entropie, kterou lze generovat, rovna entropii poskytované systémem. Ale někdy je v praktických situacích zapotřebí více náhodných čísel, než je k dispozici entropie. Procesy extrakce náhodnosti z běžícího systému jsou také ve skutečné praxi pomalé. V takových případech lze někdy použít CSPRNG. CSPRNG může „roztáhnout“ dostupnou entropii na více bitů.
Požadavky
Požadavky běžného PRNG také splňuje kryptograficky zabezpečený PRNG, ale opak není pravdivý. Požadavky CSPRNG spadají do dvou skupin: zaprvé, že procházejí statistickými údaji testy náhodnosti; a za druhé, že při vážném útoku dobře drží, i když útočníkovi bude k dispozici část jejich počátečního nebo provozního stavu.[Citace je zapotřebí ]
- Každý CSPRNG by měl uspokojit next-bit test. To je, vzhledem k prvnímu k bitů náhodné sekvence, není tam žádný polynomiální čas algoritmus, který dokáže předpovědět (k+1) th bit s pravděpodobností úspěchu nezanedbatelně lepší než 50%.[4] Andrew Yao v roce 1982 dokázal, že generátor procházející testem dalšího bitu projde všemi ostatními statistickými testy polynomiálního času pro náhodnost.[5]
- Každý CSPRNG by měl vydržet „státní kompromisní rozšíření“. V případě, že byla odhalena (nebo správně uhodnuta) část nebo celý její stav, mělo by být nemožné rekonstruovat proud náhodných čísel před odhalením. Kromě toho, pokud během provozu existuje entropický vstup, mělo by být nemožné předpovědět budoucí podmínky stavu CSPRNG pomocí znalostí o stavu vstupu.
- Příklad: Pokud uvažovaný CSPRNG produkuje výstup výpočtem bitů π v posloupnosti, počínaje od neznámého bodu v binární expanzi, může dobře uspokojit další bitový test, a tak být statisticky náhodný, protože π se jeví jako náhodná posloupnost. (To by bylo zaručeno, pokud π je a normální číslo, například.) Tento algoritmus však není kryptograficky bezpečný; útočník, který určí, který bit pí (tj. stav algoritmu) se aktuálně používá, bude schopen vypočítat také všechny předchozí bity.
Většina PRNG není vhodná pro použití jako CSPRNG a selže v obou případech. Zaprvé, zatímco většina výstupů PRNG se jeví jako náhodná pro různé statistické testy, nebrání se určenému zpětnému inženýrství. Specializované statistické testy lze nalézt speciálně naladěné na takový PRNG, který ukazuje, že náhodná čísla nejsou skutečně náhodná. Zadruhé, u většiny PRNG, když byl odhalen jejich stav, lze přehodnotit všechna minulá náhodná čísla, což umožňuje útočníkovi přečíst všechny minulé i budoucí zprávy.
CSPRNG jsou navrženy výslovně tak, aby odolávaly tomuto typu dešifrování.
Definice
V asymptotické nastavení, rodina deterministických polynomiálních časově vypočítatelných funkcí pro nějaký polynom str, je generátor pseudonáhodných čísel (PRNGnebo PRG v některých odkazech), pokud to prodlouží délku jeho vstupu ( pro všechny k), a pokud je jeho výstup výpočetně k nerozeznání ze skutečné náhodnosti, tj. pro jakýkoli pravděpodobnostní polynomiální časový algoritmus A, jehož výstupem je 1 nebo 0 jako rozlišovací znak,
pro některé zanedbatelná funkce .[6] (Zápis znamená, že X je vybrán jednotně náhodně ze sady X.)
Existuje ekvivalentní charakterizace: Pro jakoukoli rodinu funkcí , G je PRNG právě tehdy, když další výstupní bit z G nelze předpovědět polynomiálním časovým algoritmem.[7]
A bezpečný vpřed PRNG s délkou bloku je PRNG , kde je vstupní řetězec s délkou k je aktuální stav v období ia výstup (, ) se skládá z dalšího stavu a pseudonáhodný výstupní blok období i, takže vydrží rozšíření kompromisu stavu v následujícím smyslu. Pokud je počáteční stav je vybrán rovnoměrně náhodně od , pak pro všechny i, sekvence musí být výpočetně k nerozeznání od , ve kterém jsou vybrány jednotně náhodně od .[8]
Jakékoli PRNG lze změnit na dopředu zabezpečený PRNG s délkou bloku rozdělením jeho výstupu do dalšího stavu a skutečného výstupu. To se provádí nastavením , ve kterém a ; pak G je vpřed zabezpečený PRNG s jako další stát a jako pseudonáhodný výstupní blok aktuálního období.
Extrakce entropie
Santha a Vazirani dokázali, že lze kombinovat několik bitových toků se slabou náhodností, aby se vytvořil kvalitnější kvazi-náhodný bitový tok.[9]Ještě dříve, John von Neumann dokázal, že a jednoduchý algoritmus může odstranit značné množství zkreslení v jakémkoli bitovém proudu[10] který by měl být použit na každý bitový proud před použitím jakékoli varianty designu Santha – Vazirani.
Designy
V diskusi níže jsou návrhy CSPRNG rozděleny do tří tříd:
- ty založené na kryptografických primitivách, jako je šifry a kryptografické hashe,
- ti, kteří jsou založeni na matematických úlohách považovaných za těžké, a
- účelové vzory.
Poslední často zavádí další entropii, pokud je k dispozici, a přísně vzato nejde o „čisté“ generátory pseudonáhodných čísel, protože jejich výstup není zcela určen jejich počátečním stavem. Toto přidání může zabránit útokům, i když je ohrožen počáteční stav.
Návrhy založené na kryptografických primitivech
- Bezpečné bloková šifra lze převést na CSPRNG spuštěním režim čítače[pochybný ]. To se provádí výběrem a náhodný klíč a šifrování 0, poté šifrování 1, poté šifrování 2 atd. Počítadlo lze také spustit na libovolném jiném čísle než nule. Za předpokladu, že n-bitová bloková šifra, výstup lze odlišit od náhodných dat přibližně po 2n/2 bloky od, po narozeninový problém, v tomto bodě by se měly stát pravděpodobné kolizní bloky, zatímco bloková šifra v režimu CTR nikdy nevydá stejné bloky. U 64bitových blokových šifer to omezuje bezpečnou velikost výstupu na několik gigabajtů, u 128bitových bloků je omezení dostatečně velké, aby neovlivnilo typické aplikace. Pokud je však použit samostatně, nesplňuje všechna kritéria CSPRNG (jak je uvedeno výše), protože není silný proti „rozšíření kompromisu státu“: se znalostí stavu (v tomto případě pult a klíč) můžete předpovídat všechny minulé výstupy.
- Kryptograficky bezpečné hash čítače může v některých případech fungovat také jako dobrý CSPRNG. V tomto případě je také nutné, aby počáteční hodnota tohoto čítače byla náhodná a tajná. Pro použití tímto způsobem však bylo málo studií o těchto algoritmech a alespoň někteří autoři před tímto použitím varují.[vágní ][11]
- Většina proudové šifry pracovat generováním pseudonáhodného proudu bitů, které jsou kombinovány (téměř vždy XORed ) s prostý text; spuštění šifry na počítadle vrátí nový pseudonáhodný proud, pravděpodobně s delší periodou. Šifra může být zabezpečena, pouze pokud je původní stream dobrý CSPRNG, i když to tak nemusí být (viz Šifra RC4 ). Počáteční stav musí být opět utajen.
Číslově teoretické designy
- The Blum Blum Shub Algoritmus má bezpečnostní důkaz založený na obtížnosti kvadratický problém reziduaity. Jelikož jediným známým způsobem, jak vyřešit tento problém, je zohlednit modul, obecně se má za to, že obtížnost celočíselná faktorizace poskytuje podmíněný bezpečnostní důkaz pro algoritmus Blum Blum Shub. Algoritmus je však velmi neefektivní, a proto nepraktický, pokud není vyžadováno extrémní zabezpečení.
- The Algoritmus Blum – Micali má bezpečnostní důkaz založený na obtížnosti problém diskrétního logaritmu ale je také velmi neefektivní.
- Daniel Brown z Certicom napsal bezpečnostní důkaz z roku 2006 pro Dual_EC_DRBG, na základě předpokládané tvrdosti Předpoklad rozhodnutí Diffie – Hellman, x-logaritmus probléma problém se zkráceným bodem. Důkaz z roku 2006 výslovně předpokládá nižší outlen[je zapotřebí objasnění ] než ve standardu Dual_EC_DRBG a že P a Q ve standardu Dual_EC_DRBG (které byly v roce 2013 odhaleny jako pravděpodobně backdoorované NSA) jsou nahrazeny hodnotami bez backdoor.
Speciální provedení
Existuje řada praktických PRNG, které byly navrženy tak, aby byly kryptograficky bezpečné, včetně
- the Yarrowův algoritmus který se pokouší vyhodnotit entropickou kvalitu svých vstupů. Yarrow se používá v Operační Systém Mac a další Apple OS až do prosince 2019. Od té doby přešel Apple na Fortunu. (Vidět / dev / random ).
- the ChaCha20 algoritmus nahrazen RC4 v OpenBSD (verze 5.4),[12] NetBSD (verze 7.0),[13] a FreeBSD (verze 12.0).[14]
- ChaCha20 také nahrazen SHA-1 v Linux ve verzi 4.8.[15]
- the Algoritmus Fortuna, nástupce společnosti Yarrow, která se nepokouší vyhodnotit entropickou kvalitu svých vstupů. Fortuna se používá ve FreeBSD. Počínaje prosincem 2019 se Apple změnil na Fortuna pro většinu nebo všechny operační systémy Apple.
- funkce CryptGenRandom uvedené v Microsoft je Kryptografické programovací rozhraní aplikace
- ISAAC na základě varianty RC4 šifra
- Evoluční algoritmus založeno na NIST Sada statistických testů.[16][17]
- arc4random
- AES -CTR DRBG se často používá jako generátor náhodných čísel v systémech, které používají šifrování AES.[18][19]
- ANSI X9.17 standard (Správa klíčů finančních institucí (velkoobchod)), který byl přijat jako a FIPS standard také. Bere se jako vstup a TDEA (možnost klíčování 2 ) svazek klíčů k a (počáteční hodnota) 64 bitů náhodné semeno s.[20] Pokaždé, když je požadováno náhodné číslo:
- Získá aktuální datum a čas D na maximální možné rozlišení.
- Vypočítá dočasnou hodnotu t = TDEAk(D)
- Vypočítá náhodnou hodnotu X = TDEAk(s ⊕ t), kde ⊕ označuje bitové exkluzivní nebo.
- Aktualizuje osivo s = TDEAk(X ⊕ t)
- Je zřejmé, že tato technika je snadno zobecnitelná na jakoukoli blokovou šifru; AES bylo navrženo.[21]
Standardy
Několik CSPRNG bylo standardizováno. Například,
- Tento stažený standard má čtyři PRNG. Dva z nich jsou nekontroverzní a osvědčené: CSPRNG s názvem Hash_DRBG[22] a HMAC_DRBG.[23]
- Třetí PRNG v této normě, CTR_DRBG, je založen na a bloková šifra běží dovnitř režim čítače. Má nekontroverzní design, ale ukázalo se, že je slabší, pokud jde o rozlišení útoku, než úroveň zabezpečení základní blokové šifry, když je počet bitů vydaných z tohoto PRNG větší než dva k síle velikosti bloku základní šifry v bitech.[24]
- Když je maximální počet výstupů bitů z tohoto PRNG roven 2velikost bloku, Výsledný výstup poskytuje matematicky očekávanou úroveň zabezpečení, kterou by generovala velikost klíče, ale ukazuje se, že výstup není k nerozeznání od skutečného generátoru náhodných čísel.[24] Když je maximální počet výstupů bitů z tohoto PRNG menší, je doručena očekávaná úroveň zabezpečení a výstup se jeví jako nerozeznatelný od skutečného generátoru náhodných čísel.[24]
- V další revizi je uvedeno, že nárokovaná síla zabezpečení pro CTR_DRBG závisí na omezení celkového počtu požadavků na generování a bitů poskytovaných na požadavek na generování.
- Čtvrtý a poslední PRNG v této normě je pojmenován Dual_EC_DRBG. Ukázalo se, že není kryptograficky bezpečný a předpokládá se, že má kleptografické Zadní vrátka NSA.[25]
- NIST SP 800-90A Rev.1: Toto je v podstatě NIST SP 800-90A s odstraněným Dual_EC_DRBG a je to nahrazený standard.
- ANSI X9.17-1985 Dodatek C
- ANSI X9.31-1998 dodatek A.2.4
- ANSI X9.62-1998, příloha A.4, zastaralé ANSI X9.62-2005, příloha D (HMAC_DRBG)
Existují také standardy pro statistické testování nových návrhů CSPRNG:
- Sada statistických testů pro generátory náhodných a pseudonáhodných čísel, Speciální publikace NIST 800-22.
NSA kleptographic backdoor v Dual_EC_DRBG PRNG
Opatrovník a The New York Times v roce 2013 uvedli, že Národní bezpečnostní agentura (NSA) vložil a zadní dveře do generátor pseudonáhodných čísel (PRNG) ze dne NIST SP 800-90A což umožňuje NSA snadno dešifrovat materiál, který byl zašifrován pomocí Dual_EC_DRBG. Oba dokumenty referují[26][27] že, jak dlouho tušili nezávislí bezpečnostní experti,[28] NSA zavádí slabosti do standardu CSPRNG 800-90; toto poprvé potvrdil jeden z přísně tajných dokumentů, které unikly do Guardianu Edward Snowden. NSA tajně pracovala na tom, aby v roce 2006 byla schválena jeho vlastní verze bezpečnostního standardu NIST pro celosvětové použití. Uniklý dokument uvádí, že „nakonec se NSA stal jediným editorem“. I přes známý potenciál pro a kleptografické backdoor a další známé významné nedostatky u Dual_EC_DRBG, několik společností jako např Zabezpečení RSA pokračoval v používání Dual_EC_DRBG, dokud nebyly backdoor potvrzeny v roce 2013.[29] Zabezpečení RSA obdržel od NSA platbu 10 milionů dolarů.[30]
Bezpečnostní chyby
Útok DUHK
23. října 2017 Shaanan Cohney, Matthew Green, a Nadia Heningerová, kryptografové na University of Pennsylvania a Univerzita Johna Hopkinse zveřejněné podrobnosti o útoku DUHK (Nepoužívejte pevně kódované klíče) na WPA2 kde prodejci hardwaru používají napevno zakódovaný klíč pro algoritmus ANSI X9.31 RNG ve spojení s použitím generátoru náhodných čísel ANSI X9.31, „může útočník hrubou silou zašifrovat data, aby zjistil zbytek parametrů šifrování a odvodil hlavní šifrovací klíč používaný k šifrování webových relací nebo soukromá virtuální síť Připojení (VPN). “[31][32]
Japonský šifrovací stroj PURPLE
V době druhá světová válka „Japonsko použilo šifrovací stroj používaný pro diplomatickou komunikaci; Spojené státy byly schopny rozluštit to a přečíst si jeho zprávy, hlavně proto, že použité „klíčové hodnoty“ nebyly dostatečně náhodné.
Reference
- ^ Huang, Andrew (2003). Hacking the Xbox: An Introduction to Reverse Engineering. Žádná řada lisů na škrob. Žádný lis na škrob. str.111. ISBN 9781593270292. Citováno 2013-10-24.
[...] generátor klíčového proudu [...] lze považovat za kryptografický generátor pseudonáhodných čísel (CPRNG).
- ^ Dufour, Cédric. "Jak zajistit entropii a správné generování náhodných čísel ve virtuálních strojích". Exoscale.
- ^ „/ dev / random je více podobný / dev / urandom s Linuxem 5.6 - Phoronix“. www.phoronix.com.
- ^ Katz, Jonathan; Lindell, Yehuda (2008). Úvod do moderní kryptografie. CRC tisk. str.70. ISBN 978-1584885511.
- ^ Andrew Chi-Chih Yao. Teorie a aplikace funkcí padacích dveří. In Proceedings of the 23. IEEE Symposium on Foundations of Computer Science, 1982.
- ^ Goldreich, Oded (2001), Základy kryptografie I: Základní nástroje, Cambridge: Cambridge University Press, ISBN 978-0-511-54689-1, def 3.3.1.
- ^ Goldreich, Oded (2001), Základy kryptografie I: Základní nástroje, Cambridge: Cambridge University Press, ISBN 978-0-511-54689-1Věta 3.3.7.
- ^ Dodis, Jevgenij, Přednáška 5 Poznámky k úvodu do kryptografie (PDF), vyvoláno 3. ledna 2016, def 4.
- ^ Miklos Santha, Umesh V. Vazirani (1984-10-24). "Generování kvazi náhodných sekvencí z mírně náhodných zdrojů" (PDF). Sborník 25. sympozia IEEE o základech informatiky. University of California. 434–440. ISBN 0-8186-0591-X. Citováno 2006-11-29.
- ^ John von Neumann (01.03.1963). "Různé techniky pro použití ve spojení s náhodnými číslicemi". Sebraná díla Johna von Neumanna. Pergamon Press. str. 768–770. ISBN 0-08-009566-6.
- ^ Adam Young, Moti Yung (01.02.2004). Škodlivá kryptografie: Odhalení kryptovirologie. část 3.2: John Wiley & Sons. str. 416. ISBN 978-0-7645-4975-5.CS1 maint: umístění (odkaz)
- ^ „CVS log of arc4random.c“. CVS. 1. října 2013.
- ^ „CVS log of arc4random.c“. CVS. 16. listopadu 2014.
- ^ „Poznámky k vydání FreeBSD 12.0-RELEASE: Runtime Libraries and API“. FreeBSD.org. 5. března 2019. Citováno 24. srpna 2019.
- ^ „Github commit of random.c“. Github. 2. července 2016.
- ^ „Sada statistických testů pro generátory náhodných a pseudonáhodných čísel pro kryptografické aplikace“ (PDF). Zvláštní publikace. NIST. Duben 2010.
- ^ Poorghanad, A .; Sadr, A .; Kashanipour, A. (květen 2008). „Generování vysoce kvalitního pseudonáhodného čísla pomocí evolučních metod“ (PDF). Kongres IEEE o výpočetní inteligenci a bezpečnosti. 9: 331–335.
- ^ Kleidermacher, David; Kleidermacher, Mike (2012). Zabezpečení vestavěných systémů: Praktické metody pro bezpečný a zabezpečený vývoj softwaru a systémů. Elsevier. str. 256. ISBN 9780123868862.
- ^ Cox, George; Dike, Charles; Johnston, DJ (2011). „Digitální generátor náhodných čísel (DRNG) společnosti Intel“ (PDF). Citovat deník vyžaduje
| deník =
(Pomoc) - ^ Menezes, Alfrede; van Oorschot, Paul; Vanstone, Scott (1996). „Kapitola 5: Pseudonáhodné bity a sekvence“ (PDF). Příručka aplikované kryptografie. CRC Press.
- ^ Young, Adam; Yung, Moti (01.02.2004). Škodlivá kryptografie: Odhalení kryptovirologie. část 3.5.1: John Wiley & Sons. ISBN 978-0-7645-4975-5.CS1 maint: umístění (odkaz)
- ^ Kan, Wilson (4. září 2007). „Analýza podkladových předpokladů v NIST DRBG“ (PDF). Citováno 19. listopadu 2016.
- ^ Ye, Katherine Qinru (duben 2016). „The Notorious PRG: Formální ověření generátoru pseudonáhodných čísel HMAC-DRBG“ (PDF). Citováno 19. listopadu 2016.
- ^ A b C Campagna, Matthew J. (1. listopadu 2006). "Bezpečnostní hranice pro NIST Codebook-based Deterministic Random Bit Generator" (PDF). Citováno 19. listopadu 2016.
- ^ Perlroth, Nicole (10. září 2013). „Vláda oznamuje kroky k obnovení důvěry v standardy šifrování“. The New York Times. Citováno 19. listopadu 2016.
- ^ James Borger; Glenn Greenwald (6. září 2013). „Odhalení: jak špionážní agentury USA a Velké Británie poráží soukromí a zabezpečení internetu“. Opatrovník. Opatrovník. Citováno 7. září 2013.
- ^ Nicole Perlroth (5. září 2013). „N.S.A. je schopen zmařit základní záruky ochrany soukromí na webu“. The New York Times. Citováno 7. září 2013.
- ^ Bruce Schneier (15. listopadu 2007). „Uložila NSA tajný backdoor v novém šifrovacím standardu?“. Kabelové. Citováno 7. září 2013.
- ^ Matthew Green. „RSA varuje vývojáře, aby nepoužívali produkty RSA“.
- ^ Joseph Menn (20. prosince 2013). „Exkluzivní: Tajná smlouva vázána na průkopníky NSA a bezpečnostního průmyslu“. Reuters.
- ^ Shaanan Cohney; Matthew D. Green; Nadia Heningerová. „Praktické útoky na obnovení stavu proti implementacím starších RNG“ (PDF). duhkattack.com.
- ^ „DUHK Crypto Attack obnovuje šifrovací klíče, odhaluje připojení VPN“. slashdot.org. Citováno 25. října 2017.
externí odkazy
- RFC 4086 Požadavky na náhodnost pro zabezpečení
- Java „entropický fond“ pro kryptograficky bezpečná nepředvídatelná náhodná čísla.
- Standardní třída Java poskytující kryptograficky silný generátor pseudonáhodných čísel (PRNG).
- Kryptograficky zabezpečte náhodné číslo ve Windows bez použití CryptoAPI
- Vyvrácená bezpečnost eliptické křivky ANSI-NIST RNG, Daniel R. L. Brown, IACR ePrint 2006/117.
- Bezpečnostní analýza generátoru náhodných čísel eliptické křivky NIST SP 800-90, Daniel R. L. Brown a Kristian Gjosteen, IACR ePrint 2007/048. Objevit se v CRYPTO 2007.
- Kryptoanalýza pseudonáhodného generátoru duální eliptické křivky, Berry Schoenmakers a Andrey Sidorenko, IACR ePrint 2006/190.
- Efektivní pseudonáhodné generátory založené na předpokladu DDH, Reza Rezaeian Farashahi a Berry Schoenmakers a Andrey Sidorenko, IACR ePrint 2006/321.
- Analýza generátoru náhodných čísel v systému Linux, Zvi Gutterman a Benny Pinkas a Tzachy Reinman.
- NIST Statistická testovací sada dokumentace a stahování softwaru.