Autentizace dat a zpráv PV157 – Autentizace a řízení přístupu Základní pojmy • Integrita dat – data nebyla neautorizovaně změněna (vložení dat, smazání dat, přeskupení dat…) od doby vytvoření, přenosu… • Autentizace původu dat – potvrzujeme, že data pocházejí od určitého subjektu. Metody autentizace dat a zpráv • Bez použití kryptografie – CRC (Cyclic Redundancy Check). • S použitím kryptografie – Sdílený tajný symetrický klíč. – Získání haše autentizovaným kanálem. – Haš s tajným klíčem / MAC (Message Auth. Code) – dříve označováno jako digitální pečeť. – Digitální podpis. Hašování a autentizace dat • Využití jiného komunikačního kanálu – Data pošleme standardním nezabezpečeným kanálem (např. elektronickou poštou). – Spočítáme haš dat a tento haš sdělíme příjemci jiným kanálem (např. telefonicky, na vizitce předané při osobním setkání). – Příjemce spočítá haš získaných dat a porovná haše. dokument email haš telefon příjemce Elektronický podpis • Zákon o elektronickém podpisu č. 227/2000 Sb. (změněn několika novelizacemi). • „Elektronickým podpisem se rozumí údaje v elektronické podobě, které jsou připojené k datové zprávě nebo jsou s ní logicky spojené a které slouží jako metoda k jednoznačnému ověření identity podepsané osoby ve vztahu k datové zprávě“ • Elektronickým podpisem tak může být i pouhé jméno napsané na klávesnici. Není podpis jako podpis • Elektronický podpis – téměř cokoliv • Zaručený elektronický podpis – v podstatě digitální podpis • Zaručený elektronický podpis založený na kvalifikovaném certifikátu – digitální podpis, certifikát veřejného klíče vydán kvalifikovanou CA (splnila podmínky zákona a oznamovací povinnost) • Zaručený elektronický podpis založený na kvalifikovaném certifikátu od akreditovaného poskytovatele certifikačních služeb – také nazýván jako „uznávaný podpis“ – digitální podpis, certifikát veřejného klíče vydán akreditovanou CA (splnila podmínky zákona a získala akreditaci) – jen tento podpis je uznáván v komunikaci se státní správou a samosprávou – v ČR dnes tři akreditované CA (I.CA, PostSignum a eIdentity) Zaručený elektronický podpis • Je jednoznačně spojen s podepisující osobou (jen fyzická osoba!); • umožňuje identifikaci podepisující osoby ve vztahu k datové zprávě; • byl vytvořen a připojen k datové zprávě pomocí prostředků, které podepisující osoba může udržet pod svou výhradní kontrolou; • je k datové zprávě, ke které se vztahuje, připojen takovým způsobem, že je možno zjistit jakoukoliv následnou změnu dat. Elektronická značka • Jednoznačně spojena s označující osobou (i právnickou osobou nebo i org. složkou státu) a umožňuje její identifikaci prostřednictvím kvalifikovaného systémového certifikátu; • byly vytvořeny a připojeny k datové zprávě pomocí prostředku pro vytváření elektronických značek, které označující osoba může udržet pod svou výhradní kontrolou; • jsou k datové zprávě, ke které se vztahují, připojeny takovým způsobem, že je možné zjistit jakoukoli následnou změnu dat. Elektronický podpis vs. značka • Elektronický podpis – podepisující osoba je fyzická osoba, která je držitelem prostředku pro vytváření elektronických podpisů a jedná jménem svým nebo jménem jiné fyzické či právnické osoby; – pro ověření podpisu je vydáván certifikát (veřejného klíče). • Elektronická značka – označující osobou fyzická osoba, právnická osoba nebo organizační složka státu, která drží prostředek pro vytváření elektronických značek a označuje datovou zprávu elektronickou značkou; – pro ověření podpisu je vydáván systémový certifikát (veřejného klíče). Elektronický podpis vs. značka • Rozdíl je pouze procedurální – „Datová zpráva je podepsána, pokud je opatřena elektronickým podpisem. Pokud se neprokáže opak, má se za to, že se podepisující osoba před podepsáním datové zprávy s jejím obsahem seznámila.“ (§3 odst. 1) „Použití zaručeného elektronického podpisu založeného na kvalifikovaném certifikátu a vytvořeného pomocí prostředku pro bezpečné vytváření podpisu umožňuje ověřit, že datovou zprávu podepsala osoba uvedená na tomto kvalifikovaném certifikátu.“ (§3 odst. 2) – „Použití elektronické značky založené na kvalifikovaném systémovém certifikátu a vytvořené pomocí prostředku pro vytváření elektronických značek umožňuje ověřit, že datovou zprávu označila touto elektronickou značkou označující osoba.“ (§3a odst. 1) „Pokud označující osoba označila datovou zprávu, má se za to, že tak učinila automatizovaně bez přímého ověření obsahu datové zprávy a vyjádřila tím svou vůli. “ (§3a odst. 2) Elektronický podpis a značka • Technologicky jde o totéž – Jen automatizace použití a správa soukromého klíče je jiná. – Viz. §17 a §17a zákona • Podle vyhlášky min. informatiky č. 378/2006 Sb. se jedná o klasické algoritmy digitálního podpisu – Vyhláška odkazuje na CWA 14167-1 – CWA 14167-1 odkazuje na ETSI SR 002 176 Změna na přelomu 2009/2010 • „Kvalifikovaní poskytovatelé certifikačních služeb ukončí vydávání kvalifikovaných certifikátů s algoritmem SHA-1 do 31. 12. 2009. Od 1. 1. 2010 budou tito poskytovatelé vydávat kvalifikované certifikáty podporující některý z algoritmů SHA-2.“ • „Kvalifikované certifikáty s hashovací funkcí třídy SHA-2, které začnou vydávat nejpozději od 1. ledna 2010, budou všichni tři poskytovatelé přednostně nabízet s hashovací funkcí SHA-256 v kombinaci s algoritmem RSA s délkou klíče 2048 bitů. Poskytovatel certifikačních služeb může na základě vlastního rozhodnutí a základě požadavků svých zákazníků vydávat kvalifikované certifikáty i s některou z dalších funkcí z rodiny SHA-2, tj. SHA-224, SHA-384 nebo SHA-512.“ podepisovací algoritmus ověřovací algoritmuszpráva podepsaná zpráva Alice Alicin veřejný klíč Bob Převzato z: Network and Internetwork Security (Stallings) Schéma digitálního podpisu (opak.) ověřený podpis Alicin privátní klíč Digitální podpis – klíče • Každý subjekt má 2 klíče: – privátní (soukromý) klíč pro vytváření podpisu; – veřejný klíč pro ověření podpisu. • Správný digitální podpis může vytvořit jen ten, kdo má k dispozici soukromý klíč. • Pro ověření podpisu je nutné mít veřejný klíč podepsaného subjektu. • Digitální podpis nedává sám o sobě žádnou záruku o době jeho vytvoření. Digitální podpis – co podepisujeme? • Algoritmy digitálního podpisu založené na asymetrické kryptografii jsou relativně pomalé. • V praxi nepodepisujeme celý dokument (velikosti v kB, MB i GB) ale pouze haš (fixní délky řádově stovky bitů). • Není bezpečné rozdělit dokument na několik částí a ty podepsat separátně. • Při kombinaci šifrování veřejným klíčem a podpisu je nutné dokument nejprve podepsat a pak teprve zašifrovat. Digitální podpis – bezpečnost • Pro bezpečnou funkčnost digitálního podpisu je nezbytně nutné: – udržovat privátní klíč v tajnosti – každý, kdo má přístup k privátnímu klíči má možnost vytvářet platné podpisy; – zajistit integritu veřejného klíče – pokud bychom ověřovali platnost podpisu pomocí nesprávného klíče můžeme dojít k nesprávným závěrům. Digitální podpis – integrita VK • Jak zajistit integritu veřejného klíče? • Pomocí certifikátu veřejného klíče! • Certifikát váže veřejný klíč k subjektu (spíše k nějakému identifikátoru subjektu). • Tato vazba je digitálně podepsána důvěryhodnou třetí stranou (certifikační autoritou). • Jak zajistit integritu veřejného klíče certifikační autority? Digitální podpis • Jak udržovat důvěrnost privátního klíče? • Key recovery – obnova klíčů!? • Některé algoritmy asymetrické kryptografie umožňují používat jednu dvojici klíčů pro šifrování i podpis – toto však není příliš vhodná kombinace. • Jak se brání zaměstnavatel vůči odchodu zaměstnance?  Rozdílný přístup k šifrovacímu a podepisovacímu klíči! Digitální podpis – algoritmy • První algoritmy asymetrické kryptografie na začátku 70. let 20. století: – Britská tajná služba GCHQ (Clifford Cocks). – Veřejné oznámení až koncem 20. století (1997). – Aplikaci algoritmů pro autentizaci – podpis – „objevila“ později až akademická komunita u svých veřejných algoritmů. • První veřejné algoritmy koncem 70. let 20. století (W. Diffie a M. Hellman ovlivněni prací R. Mercla). • Nejznámější algoritmus RSA (Rivest, Shamir, Adelman) publikován v roce 1977, patentován v roce 1983 (v současné době patent již vypršel). Digital Signature Algorithm • V roce 1994 proběhl v USA výběr Digital Signature Standard (DSS) – vyhrál DSA (Digital Signature Algorithm) modifikovaný algoritmus ElGamal, založený na diskrétním logaritmu v Zp. • Další algoritmy, mj. založeny i na eliptických křivkách. • NIST FIPS 186-3 nyní podporuje RSA (podle PKCS#1), DSA (3072 bitů) a ECDSA (podle ANSI X9.62). Digitální podpis – délky klíčů • Algoritmus RSA – Při jednom z popisů algoritmu (ve „Scientific American“ v roce 1977) autoři publikovali příklad kryptosystému (prvočísla byla 64- a 65bitová), o kterém věřili, že je bezpečný. – Tento příklad byl rozlomen v roce 1994. – Koncem roku 1999 došlo k prolomení 512bitového modulo RSA (několik set rychlých počítačů pracovalo přes 4 měsíce), nedávno byl faktorizován 768 bitový RSA klíč. – V současné době se používá modulo o délkách 1024 až 4096 bitů. Digitální podpis – časová náročnost • Algoritmy asymetrické kryptografie jsou relativně časově náročné – příklady časů pro čipovou kartu 50 ms160 bitů160 bitůOvěření EC DSA (GF(p)) 24 ms160 bitůPodpis EC DSA (GF(p)) 14,4 s2048 bitůGenerování klíče RSA 1,56 s1024 bitůGenerování klíče RSA 38 ms2048 bitůOvěření RSA 2,8 ms32 bitů1024 bitůOvěření RSA 0,17 s2048 bitů2048 bitůPodpis RSA 25,2 ms1024 bitů1024 bitůPodpis RSA ČasExponentModulusOperace Digitální podpis – časová náročnost RSA ECDSA Digitální podpis – RSA– matematika • Násobení prvočísel snadné, ale faktorizace čísel výpočetně náročná. • Velká prvočísla p a q, n = p·q, φ(n) = (p-1)(q-1). • Zvolíme velké e takové, že gcd(e, φ(n)) = 1. • Spočítáme d = e-1 (mod φ(n)). • Veřejný klíč: n, e. Neveřejné parametry: p, q, d. • Šifrování: c = we mod n. • Dešifrování: w = cd mod n. Digitální podpis – RSA– příklad • Čísla jsou úmyslně příliš malá (takový systém není bezpečný). • Parametry: p = 7927, q = 6997, n = pq = 55465219, φ(n) = 7926  6996 = 55450296. • Alice volí e = 5, řeší rovnici ed = 5d = 1 (mod 55450296), d = 44360237. • Alicin veřejný klíč: (n = 55465219, e = 5), privátní klíč: d = 44360237. • Podpis: m = 31229978; s = 3122997844360237 mod 55465219 = 30729435. • Ověření podpisu: m = 307294355 mod 55465219 = 31229978. • Podpis je ověřen, pokud je přijata zpráva m=31229978. Výpočetní bezpečnost • Bezpečnost RSA je založena na nesnadnosti faktorizace čísel. • Je zřejmé, že pouhým „vyzkoušením“ všech čísel do odmocniny z n se nám podaří n faktorizovat. • Bezpečnost RSA je založena na tom, že faktorizovat velká čísla (tím v současné době myslíme čísla o tisících bitů) v rozumném čase neumíme. • Pokrok v oblasti faktorizace čísel (například nalezení nového algoritmu) však může znamenat, že z veřejného klíče budeme schopni odvodit klíč privátní. • Tento algoritmus je založen na tzv. „výpočetní bezpečnosti“ (nejen tento algoritmus, „výpočetní bezpečnost“ je běžně používaný přístup). Bezpečnost RSA Zdroj: P. Layland, RSA Security and Integer Factorization: The Thirty Years War from 1990 to 2020, IS2 2010, Praha Hašovací funkce • Kryptografická hašovací funkce. • Vstup libovolné délky. • Výstup pevné délky: n bitů (typicky 256). • Funkce není prostá (vznikají kolize). • Haš slouží jako kompaktní reprezentace vstupu (nazýváme též otisk, anglicky imprint, digital fingerprint nebo message digest). • Hašovací funkce často používáme při zajišťování integrity dat. Spočítáme nejprve haš a pak pracujeme s tímto hašem (například jej podepíšeme). • Právě probíhá výběr nového algoritmu SHA-3! SHA-3 • Finalisté soutěže – BLAKE – Grøstl – JH – Keccak – Skein • Vítěz očekáván koncem tohoto roku Vlastnosti hašovacích funkcí • Jednosměrnost – Pro libovolné x je snadné spočítat h(x). – V rozumném čase nejsme schopni pro pevně dané y najít takové x, že h(x) = y. • Bezkoliznost – (slabá): pro dané x nejsme schopni v rozumném čase najít x’ (x ≠ x’) takové, že h(x) = h(x’). – (silná): v rozumném čase nejsme schopni najít libovolná x, x’ taková, že h(x) = h(x’). Příklad hašovací funkce • Uvažujme následující hašovací funkci: – Jednoduchý součet bajtů modulo 256 . – Fixní osmibitový výstup. – Pro text „ahoj“ získáme 97+104+111+106 mod 256 = 162. • Tuto funkci je sice jednoduché spočítat, není to však dobrá kryptografická hašovací funkce, neboť nemá vlastnost bezkoliznosti. • h(„ahoj“) = h(„QQ“) = h(„zdarFF“) Běžné kryptografické hašovací funkce • MD4: výstup 128 bitů – dnes se již nepoužívá – byly nalezeny slabiny v algoritmu (umožňující nalezení kolizí, snižující efektivní výstup asi na 20 bitů). • MD5: výstup 128 bitů – dnes ještě používána, ačkoliv byly nalezeny významné slabiny a algoritmus pro nalezení kolizí – 128 bitů se již nepovažuje za dostatečně bezpečnou délku! • SHA-1 (Secure Hash Algorithm): výstup 160 bitů – NIST standard, používána v DSS (Digital Signature Standard). – NIST od roku 2010 nedoporučuje (americkým vládním organizacím) používat SHA-1. • „SHA-2“ – SHA-256, SHA-384, SHA-512 (a dodána SHA-224) – doporučuje se používat především tyto funkce! Definovány ve standardu (NIST) FIPS 180-2. • Nově přidány funkce SHA-512/224 a SHA-512/256. Hašovací funkce – příklady • MD5 – Vstup: „Autentizace“. – Výstup: 2445b187f4224583037888511d5411c7 . – Výstupem je 128 bitů, zapisujeme hexadecimálně. – Vstup: „Cutentizace“. – Výstup: cd99abbba3306584e90270bf015b36a7. – Změna jednoho bitu vstupu → velká změna výstupu. • SHA-1 – Vstup: „Autentizace“. – Výstup: dfcee447d609529f0335e67016557c281fc6eb44 . Hašovací funkce z šifrovacích algoritmů • Hašovací funkci můžeme vytvořit z libovolné blokové symetrické šifry. • Existují postupy pro vytvoření hašovací funkce s délkou haše o velikosti délky bloku či dvojnásobku délky bloku. Matyas-Meyer-Oseas Eg xi Hi Hi-1 Narozeninový paradox • Zajímavé útoky na hašovací funkce vycházejí z tzv. birthday (narozeninového) paradoxu. • Pravděpodobnost, že 2 lidé v sále s 23 lidmi mají narozeniny ve stejný den je více než 50 %. Tato pravděpodobnost je překvapivě vysoká a s počtem lidí v sále dále rychle roste (při 30 lidech v sále je vyšší než 70 %). • Tohoto můžeme využít při hledání kolizí hašovací funkce (tj. pokud nám jde o LIBOVOLNOU kolizi máme větší šanci, než při kolizi se specifickou hodnotou haše). Integrita dat – CRC • Detekce chyb (error detection) – Kontrolní součty – paritní bity, aritmetický součet modulo, exkluzivní součet (XOR). – CRC (cyclic redundancy check) – cyklický kontrolní součet. Např. 16-bitový g(x) = 1+x2+x15+x16 . – Slouží k detekci (neúmyslných) chyb při přenosu dat, uložení dat apod. – Je snadné spočítat kontrolní součet dat i vytvořit data odpovídající určitému kontrolnímu součtu, proto kontrolní součty neposkytují ochranu před úmyslnou modifikací dat. Integrita dat – MAC • Autentizační kódy (též digitální pečetě, message authentication code – MAC) – Slouží k zajištění integrity dat (ne důvěrnosti dat). – Původce a příjemce dat sdílí tajný klíč k. – Původce zprávy spočítá hk(x), které přidá ke zprávě x. – Příjemce zprávy spočítá hk(x’) z přijaté zprávy x’ a srovná s přijatým hk(x). Zpráva MAC Jak získat funkci pro vytváření MAC? • MAC můžeme získat z libovolné symetrické šifry v CBC (cipher block chaining) režimu (kdy zašifrovaná data závisí na všech předchozích datech). • MAC můžeme získat i z hašovací funkce, např. tajný prefix, sufix. HMAC(x) = h(k||p1||h(k||p2||x)) k klíč, p padding (doplnění dat) MAC • Příklad: MAC založený na AES AES AES AES… x1 x2 xt 0 k k k H1 H2 Ht-1 „Chaffing and winnowing“ • Metoda „chaffing and winnowing“ (oddělení zrn od plev). • Použití MAC pro zajištění důvěrnosti. • Zprávu rozdělíme na jednotlivé bity. • Pro každý bit vytvoříme 2 zprávy (obsahující 0 a 1), jednu se správným MAC a jednu s nesprávným MAC. Tyto 2 zprávy v náhodném pořadí odešleme příjemci. • Příjemce dostane 2 zprávy, tu se správným MAC si ponechá a tu druhou zahodí. • Nikdo, kdo nezná tajný sdílený klíč, není schopen odlišit zprávu se správným a nesprávným MAC. • Existují i efektivnější metody než posílání po 1 bitu. Praktická ukázka autentizace dat • Autentizace spustitelných EXE souborů v prostředí Microsoft Windows • Proč autentizujeme? – Chceme zajistit integritu programů. – Chceme znát autora programu. – Věříme například jen kódu od firmy Microsoft a chceme mít jistotu, že kód při přenosu někdo nemodifikoval, či nepodstrčil. Microsoft Autenticode • Jak autentizace funguje? • EXE soubor je digitálně podepsaný. • Digitální podpis je ověřen. • Pokud je podpis platný, aplikace je (automaticky) spuštěna. • Je-li podpis neplatný nebo není-li EXE soubor podepsán, je interaktivně dotázán uživatel. Microsoft Autenticode • Dialogové okno ve starších verzích Windows: Microsoft Autenticode • Nepodepsaný program: Authenticode dnes Microsoft Authenticode • Autentizovaná data – Při bezchybné autentizaci dat víme, že data byla získána z uvedeného zdroje (např. od firmy Microsoft) a že nebyla modifikována. – Autentizace dat neznamená, že data jsou správná, programy bezchybné, bezpečné apod. Microsoft Autenticode • 100% bezpečnost neexistuje! • V roce 2001 získal neznámý útočník 2 certifikáty veřejného klíče určené pro firmu Microsoft a podepsané firmou Verisign (obě firmy jsou klíčoví hráči ve svém oboru a určitě mají pečlivě propracované bezpečnostní předpisy). • Útočník se úspěšně vydával za zaměstnance firmy Microsoft a získal certifikát podepsaný firmou Verisign včetně soukromého klíče. • Jakýkoliv kód podepsaný takto certifikovaným klíčem bude ve Windows spuštěn bez úvodního varování (dnes jsou již certifikáty „revokovány“). Odvolané certifikáty… Otázky? Vítány!!! Příští přednáška 10. 4. 2012 v 10:00 PÍSEMKA 3. 4. 2012: 10:00 10:35 11:15 zriha@fi.muni.cz matyas@fi.muni.cz