Bankovní institut vysoká škola Praha
Základní šifrovací systémy a moderní aplikace šifer Bakalářská práce
Jan Šrámek
Březen 2009
Bankovní institut vysoká škola Praha Katedra informačních technologií
Základní šifrovací systémy a moderní aplikace šifer Bakalářská práce
Autor:
Jan Šrámek Informační technologie, auditor informačních systémů
Vedoucí práce:
Praha
Ing. Vladimír Beneš
Březen 2009
Prohlášení: Prohlašuji, že jsem bakalářskou práci zpracoval samostatně a s použitím uvedené literatury.
podpis autora V Praze dne 21. 3. 2009
Jan Šrámek
Anotace Tato bakalářská práce si klade za cíl zmapovat a popsat historii vzniku šifer, jejich vývoj a význam. Mimo řady historických informací a souvislostí se práce zabývá popisem symetrických a matematických metod šifrování. Dále kryptografií s veřejným klíčem a kvantovou kryptografií. Práce zkoumá základní principy asymetrické kryptografie a srovnává nejznámější kryptografické algoritmy které se v současné době používají v informačních a komunikačních technologiích.
Annotation This bachelor´s study aims to map and describe the history of the emergence of ciphers, their evolution and significance. Outside the range of historical information and context, the work deals with a mathematical description of symmetric encryption methods. Furthermore, with public key cryptography and quantum cryptography. Work explores the basic principles of asymmetric cryptography, and compares the best-known cryptographic algorithms that are currently used in information and communication technologies.
Obsah 1
Vznik a historie šifer 1.1 Caesarova šifra
6
1.2 Jednoduché substituční šifry
8
1.2.1
Statistiky jazyka
12
1.4 Transpoziční šifry
14
Superšifrování
16
1.6 Rozvoj kryptologie a souvislosti
17
Symetrické a matematické metody šifrování
5
21
2.1 Proudové šifry
21
2.2 Blokové šifry
24
Typy blokových šifer
2.3 Používání symetrických algoritmů k autentizaci a ověření integrity dat
4
16
1.5 Základní koncepty
2.2.1
3
10
1.3 Vigenérova šifra
1.4.1
2
6
Asymetrické metody šifrování
26 27 29
3.1 Útoky na systémy s veřejnými klíči
31
3.2 Hashovací funkce
33
3.3 Digitální podpisy
34
Kvantová kryptografie
36
4.1 Systém kvantové kryptografie
38
4.2 Jak pracuje kvantová distribuce klíčů
40
4.3 Praktické použití kvantové kryptografie
41
Novodobé trendy v kryptografii
43
5.1 Teleportace
43
5.2 Spolehlivá šifra zapsaná do miniaturních částic
45
5.3 Superrychlý počítač
46
1 Vznik a historie šifer Kryptografie neboli šifrování je nauka o metodách utajování smyslu zpráv a převod do podoby, která je čitelná jen se speciální znalostí. Slovo kryptografie pochází z řečtiny – kryptós je skrytý a gráphein znamená psát. Někdy je pojem obecněji používán pro vědu o čemkoli spojeném se šiframi jako alternativa k pojmu kryptologie. Kryptologie zahrnuje kryptografii a kryptoanalýzu, neboli luštění původní zprávy se šifrového textu.
Obrázek 1: schéma šifrovacího systému
Níže uvedené algoritmy jsou již zastaralé a nic nevypovídají o technikách moderní kryptografie. Přesto může studium raných systémů založených na záměně písmen (tzv. substituce písmen, substituční metoda) nebo změně pořadí písmen ve slově poskytnout řadu zajímavých informací. Je tomu tak z mnoha důvodů. Jedním z nich je, že představují jednoduché a snadno pochopitelné příklady, na nichž si můžeme ukázat základní koncepty a zároveň na nich můžeme demonstrovat mnoho slabin, na něž si šifry musejí dávat pozor.
1.1
Caesarova šifra
Jednou z nejstarších šifer je takzvaná Caesarova šifra, kterou popsal Julius Caesar ve svých Zápiscích o válce galské. Její princip je založen na tom, že každé písmeno od A do W je během šifrování zaměněno za písmeno, které se v abecedě nachází o tři místa dále. Písmena X, Y, a Z jsou nahrazena symboly A, B a C. Ačkoliv Caesar používal posun o tři místa, stejného výsledku lze docílit použitím libovolného čísla
6
od 1 do 25. Jakékoliv šifrování za pomoci posunu písmen tedy dnes označujeme jako Caesarovu šifru. K vysvětlení šifry nám pomůže obrázek. Vidíme na něm dva soustředné prstence, přičemž ten vnější se může volně otáčet. Jestliže začneme v pozici kdy A přiléhá k A, při posunu o 2 místa se vedle A ocitne C a tak dále. Počítáme-li posun i o 0 (který je ve výsledku stejný jako o 26), máme celkem 26 možných nastavení. U Caesarovy šifry je šifrovací i dešifrovací klíč definován posunem.
Obrázek 2: „Přístroj“ na implementaci Caesarovy šifry Zdroj: MURPHY, Sean; PIPER, Fred, Kryptografie
Jakmile se obě strany dohodnou na posunu, probíhá šifrování tak, že se písmena z otevřeného textu umisťují na vnitřní prstenec a nahrazují se písmenem z prstence vnějšího. K dešifrování stačí použít obrácený postup. Chceme-li tedy zašifrovat otevřený text PES s použitím posunu o tři písmena dostaneme řetězec SHV. V našem popisu Caesarovy šifry se šifrovací i dešifrovací klíč rovnají posunu ale šifrovací a dešifrovací postupy se od sebe liší. Stačí ovšem trochu pozměnit formulaci aby byly oba postupy shodné ale šifrovací a dešifrovací klíče různé. Jak jsem již naznačili, posun 0 písmen se rovná posunu o 26 písmen. Tudíž při šifrování s posunem 0 až 25 můžeme text dešifrovat stejným způsobem, když za posun zvolíme 26 mínus posun při šifrování. Takže například šifrování s posunem 8 je stejné jako dešifrování s posunem 26-8=18. Díky tomu můžeme pro šifrování i dešifrování použít stejný postu, přičemž šifrovací klíč (s posunem) 8 odpovídá dešifrovacímu klíči 18. Hlavní nevýhoda této šifry je její zranitelnost hrubou silou. Vzhledem k tomu, že Caesarova šifra má u běžné latinky pouze 26 možných klíčů, je tímto druhem útoku
7
velice zranitelná. Další slabinou je, že klíč lze odvodit ze znalosti jediného páru řetězců otevřeného a šifrového textu. To je až příliš málo na to aby to bylo bezpečné.[1]
1.2
Jednoduché substituční šifry
Z hlediska kryptografické bezpečnosti je sice nezbytné mít velké množství klíčů ale současně musíme zdůraznit, že to samo o sobě není žádnou zárukou síly systému. Klasickou
ukázkou
může
být
„jednoduchá
substituční
šifra“
(neboli
monoalfabetická). Rozborem této šifry se nejen názorně přesvědčíme, že velké množství klíčů není žádnou zárukou neprolomitelnosti systému, ale navíc nám ukáže jak může útočník ke svému prospěchu využít statistiky daného jazyka – v tomto případě angličtiny. U jednoduché substituční šifry si nejprve napíšeme všechna písmena abecedy ve správném pořadí a pod ně poté písmena v náhodném pořadí. Zde je příklad. ABCDEFGHIJKLMNOPQRSTUVWXYZ
správné pořadí
DIQMTBZSYKVOFERJAUWPXHLCNG
náhodné pořadí
Šifrovací a dešifrovací klíče jsou navzájem shodné. Jedná se o pořadí v jakém jsou napsána tučná písmena. Šifrovacím pravidlem je „nahradit každé písmeno tím, které je pod ním“, dešifrovací proces je přesně opačný. Pokud bychom tedy použili klíč s výše uvedeného obrázku, slovo GET by po zašifrování vypadalo jako ZTP a zpráva IYZ znamená ve skutečnosti BIG. Mimochodem Caesarova šifra je vlastně zvláštním případem jednoduché substituční šifry. Počet klíčů v jednoduché substituční šifře se rovná počtu způsobů kolika je možné seřadit 26 písmen abecedy. Jedná se o faktoriál 26 (26! = 26x25x24……x2x1), což se rovná číslu 403291461126605635584000000 To je nepochybně opravdu velké číslo, takže by se někdo stěží pokoušel odhalit klíč postupným probíráním veškerých možností. Ovšem z takto nesmírného počtu klíčů vyplívá celá řada potíží a při správě klíčů u jednoduché substituční šifry často narazíte na několik takřka ukázkových problémů. Nejevidentnější ze všech je fakt, že klíč je na rozdíl od Caesarovy šifry dlouhý a těžko zapamatovatelný. Takže v dobách
8
před počítači, kdy bylo nutné tento druh systému aplikovat ručně, se klíč často zapisoval na kus papíru. Jestliže někdo papír někdo viděl nebo dokonce ukradl, ocitl se celý systém v nebezpečí. A když jej zodpovědná osoba ztratila, byly ztraceny i všechny šifrované zprávy protože ani zamýšlenému příjemci nezbývalo nic jiného než zkusit prolomit šifrovací algoritmus. Ve snaze předejít tomuto nebezpečí se uživatelé snažili vymyslet systém generování klíčů tak, aby bylo možné si je zapamatovat. Běžnou metodou bylo určit nějakou klíčovou větu, odstranit z ní všechna opakující se písmena a takto vytvořit „začátek“ klíče, za něž se poté v abecedním pořadí zařadila veškerá zbývající písmena. Jako příklad si můžeme vzít větu „We hope you enjoyed this book“. Když z ní odstraníme opakující se znaky, dostaneme „wehopyunjtisbk“. Celý klíč tedy zní: W E H O P Y U N J T I S B K A C D FGLMQRVXZ Je zřejmé, že omezením klíčů na ty, jež jsou odvozeny od klíčové věty, se počet možností značně sníží, protože většině z 26! klíčů jednoduché substituce nelze odvodit z žádné věty, a to v jakémkoliv jazyce. Přesto je však počet klíčů dostatečně velký na to, aby nebyl útok hrubou silou proveditelný, a zároveň je možné si kód zapamatovat. Druhou nápadnou slabinou jednoduchých substitučních šifer je fakt, že mnoho různých klíčů zašifruje stejnou zprávu do stejného kryptogramu. Máme například text „Meet me tonight“ (setkáme se dnes večer). Jestliže použijeme výše uvedený klíč, dostaneme kryptogram FTTP FT PREYZSP. Stejný kryptogram bude ovšem vytvořen libovolným klíčem, který přiřadí E k T, G k Z, H k S, I k Y, M k F, N k E, O k R a T k P. A takových klíčů je 18! = 6402373705728000 To znamená, že přinejmenším u tohoto typu šifer bychom se neměli spoléhat na to, že k získání naší zprávy ze zachyceného kryptogramu musí útočník určit celý klíč.
9
1.2.1 Statistiky jazyka V případě kdy je jednoduchá substituční šifra použita k zakódování i poměrně dlouhého textu, existuje celá řada přímých útoků, s jejichž pomocí lze odhalit text původní zprávy a použitý klíč, nebo alespoň jeho velkou část. Tyto útoky se opírají především o všeobecně známé charakteristiky použitého jazyka.
Písmeno A B C D E F G H I J K L M
% 8,2 1,5 2,8 4,2 12,7 2,2 2,0 6,1 7,0 0,1 0,8 4,0 2,4
Písmeno N O P Q R S T U V W X Y Z
% 6,7 7,5 1,9 0,1 6,0 6,3 9,0 2,8 1,0 2,4 2,0 0,1 0,1
Tabulka 1: Relativní četnost písmen v anglickém textu, PIPER, F.; BACKER, J., Cipher systems
V tabulce 1 je zachycena četnost výskytu jednotlivých písmen abecedy v anglicky psaném textu. Výpočet byl proveden ze vzorku více než 300 000 znaků z různých pasáží mnoha novinových článků a knih. (tuto tabulku původně sestavili H. J. Beker a F.C. Piper a vydali jí ve své knize Cipher systems: The protection of Communications – Šifrovací systémy: ochrana komunikací). Hodnoty v této tabulce jsou srovnatelné s těmi, které ve svých odborných přehledech publikovali i mnozí jiní autoři a lze je interpretovat jako pravděpodobný výskyt daných písmen v anglicky psaném textu. Jak vidno, v angličtině zaujímá dominantní postavení jen poměrně malý počet znaků. Při použití jednoduché substituční šifry je každé písmeno abecedy nahrazeno příslušným substitučním znakem bez ohledu na své postavení v textu. Pokud tedy použijeme šifru, ve které je E zaměněno za R, bude četnost výskytu R v kryptogramu totožná s četností výskytu E v původní správě. To znamená, že pokud frekvence písmen ve zprávě odpovídá tabulce 1, bude i rozvrstvení v kryptogramu 10
stejné, jen se bude lišit rozdělení mezi jednotlivé znaky. Pro názornost si to ukážeme v praxi na dlouhém kryptogramu, který jsme získali pomocí jednoduché substituční šifry. Při
porovnání
získaných
údajů
s tabulkou
1
může
kryptoanalytik
dojít
k oprávněnému názoru, H odpovídá písmenu E a W odpovídá písmenu T. Vzhledem k tomu, že nejčastějším slovem se třemi písmeny je zcela bezkonkurenčně THE (určitý člen)., může si útočník svůj předpoklad ověřit vyhledáním řetězce W*H v kryptogramu, přičemž * představuje nějaký další znak. Tím si nejen potvrdí správnost svého odhadu, ale navíc odhalí, který znak (*) je ekvivalentem H v otevřeném textu.
Graf 1: Sloupcový graf znázorňující relativní četnost výskytu písmen v kryptogramu získaného jednoduchou substituční šifrou z anglického textu. Zdroj: MURPHY, Fred; PIPER, Sean, Kryptografie
Na závěr je třeba přesněji definovat výraz „dlouhý kryptogram“. Problém však je, že neexistuje přesná odpověď na tuhle otázku. Máme-li text zhruba o 200 znacích, pak je statistika poměrně spolehlivá. Na druhou stranu musím zdůraznit, že není žádná záruka, že se budou statistiky všech zpráv přesně shodovat s hodnotami z tabulky 1.
11
1.3
Vigenérova šifra
Vigenérova šifra je pravděpodobně nejznámější „manuální“ polyalfabetickou šifrou. Své jméno nese po Blisovi de Vigenére, francouzském diplomatovi ze 16. století. Ačkoliv byl její koncept publikován již roku 1586, širšího využití se dočkalas o 200 let později a prolomit se ji podařilo až Babbagovi a Kasiskému v polovině 19. Století. Za zmínku jistě stojí, že Vigenérovu šifru používala konfederační armáda v Americké občanské válce. Ta ovšem propukla až poté, co bylo tato šifra prolomena. Vigenérova šifra používá k šifrování tzv. Vigenérův čtverec. Sloupec po levé straně (klíčový sloupec obsahuje anglickou abecedu. Každé písmeno má svou vlastní řadu, v níž je taktéž celá abeceda, ale je posunuta v závislosti na klíčovém znaku v prvním sloupci. Tudíž každé písmeno v levém sloupci tvoří Caesarovu šifru, jejíž posun je určen právě tímto písmenem. Například u písmene g je Caesarova šifra s posunem 6.
Obrázek 3: Vigenérův čtverec, http://www.google.cz/
12
Jedna z nejběžnějších metod použití čtverce k získání šifry je zvolit si klíčové slovo (nebo větu), ve které se neopakují žádná písmena. Jestliže je otevřený text delší než klíčové slovo, opakuje se klíč, tak dlouho, jak je zapotřebí, abychom vytvořili řetězec stejně dlouhý jako původní zpráva. Ten si také pod zprávu zapíšeme. Zkusíme-li například zašifrovat slovo PLAINTEXT (otevřený text) klíčovým slovem „fred“, dostaneme: Zpráva:
PLAINTEXT
Klíč:
FREDFREDF
Nyní zprávu zašifrujeme s použitím čtverce tak, jak je napsáno níže. K zašifrování prvního písmene P použijeme klíčové písmeno pod ním, jímž je v tomto případě f. Takto pro zašifrování P přejdeme ve čtverci na řádek označený jako f a přečteme písmeno, které se nachází ve sloupci P. Tím je v našem případě U. Stejným způsobem zašifrujeme L – vezmeme písmeno ve stejném sloupci a v řádku označeném písmenem r, čímž získáme C. Když tento proces zopakujeme pro všechna písmena, zjistíme, že kryptogram pro zprávu PLAINTEXT vytvořený klíčem fred je UCELSLIAY. Výsledek je následující:
Zpráva
PLAINTEXT
Klíč
FREDFREDF
Šifrovaný text
UCELSLIAY
Písmeni T z otevřeného textu je v šifrové textu reprezentováno znaky L a Y a na druhou stranu písmeno L zastupuje v šifrové textu I a T z textu otevřeného. Je tedy zřejmé, že na rozdíl od jednoduchých substitučních šifer zde nelze k získaní původního textu použít frekvenci výskytu jednotlivých písmen. Vigenérovy šifry jsou jedním z příkladů polyalfabetických šifer, u nichž je opakovaně použita (krátká) sekvence jednoduchých substitučních šifer s pevně danou rotací. Počet šifer, z nichž se celek skládá, se nazývá perioda. U výše představené Vigenérovi šifry je perioda shodná s délkou klíčového slova.
13
Jedním z důvodů pro používání polyalfabetických šifer je snaha zamaskovat četnost výskytu jednotlivých písmen v daném jazyce. Pro ilustraci toho, jak to funguje, přikládám histogram, v němž najdete frekvenci výskytu písmen v kryptogramu, který jsem získali z anglického textu Vigenérovou šifrou s periodou 3.
Graf 2: Sloupcový graf, který znázorňuje relativní četnost výskytu písmen v kryptogramu získaného třemi jednoduchými substitučními šiframi s pevně danou rotací. MURPHY, S.; PIPER, F., Kryptografie
Na první pohled je patrné, že mezi tímto histogramem a tím, který je uveden dříve, jsou výrazné rozdíly. Nejnápadnější je, že žádné písmeno zde nevyčnívá nad ostatními tak, jako to bylo v minulém histogramu u znaku H. Druhý graf je bezesporu vyrovnanější než ten první, a neposkytuje tedy potencionálnímu útočníkovi tolik záchytných bodů. Při pohledu na druhý histogram by se sice mohla naskýtat myšlenka, že písmeno R alespoň částečně zastupuje E, ovšem nelze nijak určit kde a jak.[1]
1.4
Transpoziční šifry
Ve všech případech, o kterých jsem se zmiňoval výše, jsou jednotlivá písmena či jejich skupiny nahrazovány jinými písmeny a skupinami. Proto tyto příklady spadají do kategorie substitučních šifer. Existují však i další typy šifer, jež jsou založeny na principu změny pořadí, v jakém jsou písmena napsána. Těmto metodám se říká transpoziční šifry. Uvedu jeden velice prostý příklad. Za klíč si zvolíme nějaké malé číslo, třeba 5. Chceme-li zašifrovat pomocí tohoto klíče, napíšeme ji do řádek o pěti
14
písmenech. Poté text zapíšeme za sebe s tím, že postupujeme po sloupcích – nejprve napíšeme písmena z prvního sloupce, poté ze sloupce druhého a tak dále. Jestliže počet znaků není dělitelný pěti, přidáme na konec potřebný počet písmen Z. Pro vysvětlení si to předvedeme v praxi. Chceme zašifrovat zprávu „WHAT WAS THE WEATHER LIKE ON FRIDAY „ (jaké počasí bylo v pátek). Klíčem je číslo 5. Takže zapíšeme text do řádek o pěti písmenech, Dostaneme: WHATW ASTHE WEATH ERLIK EONFR IDAY Délka zprávy není dělitelná pěti, musíme na konec přidat Z, takže získáme: WHATW ASTHE WEATH ERLIK EONFR IDAYZ Nyní zapíšeme obsah sloupců, takže dostaneme následující kryptogram: WAWEEIHSERODATALNATHTIFYWEHKRZ Dešifrovací klíč získáme prostým vydělením délky zprávy šifrovacím klíčem. V tomto případě vydělíme 30 číslem 5, takže získáme 6. Dešifrovací algoritmus je shodný se šifrovacím. V tomto případě tedy zapíšeme kryptogram do 6 řad, čímž Získáme: WAWEEI HSEROD ATALNA THTIFY WEHKRZ Správnost postupu si můžeme snadno ověřit tím, že přečteme zprávu po sloupcích – a získáte tím původní zprávu.
15
Transpoziční šifry uvedeného typu lze prolomit poměrně snadno. Vzhledem k tomu, že klíč je zároveň dělitelem délky kryptogramu, stačí útočníkovi spočítat počet znaků v šifrové textu a zkusit všechny možné dělitele.
1.4.1 Superšifrování Kombinací dvou nebo více slabších šifer získáme systém, který se mnohem silnější. Tomuto způsobu se říká skládání šifer. Základní myšlenka je velice prostá. Jestliže například chceme zprávu superšifrovat pomocí jednoduché substituční šifry a transpoziční šifry, nejprve na zprávu použijeme jednoduchou substituční šifru a výsledný kryptogram ještě zašifrujeme pomocí výše nastíněné transpozice.[1]
1.5
Základní koncepty
Hlavním cílem každého šifrovacího systému je zamaskovat utajovanou zprávu, tak aby byla pro všechny nepovolané osoby zcela nečitelná. Šifrovací systémy zřejmě nejčastěji ke slovu ve chvíli, když chceme data bezpečně uložit do počítačového souboru nebo pokud je posíláte nezabezpečeným kanálem, jako je např. internet. V obou případech zašifrování dokumentu sice nezajistí, aby nepadl do nepovolaných rukou ale zabrání tomu aby někdo porozuměl jeho obsahu. Informaci, kterou je nutno nějakým způsobem zabezpečit, většinou označujeme jako otevřený text, proces zabezpečování zprávy pak jako šifrování. Zabezpečený otevřený text se stává šifrovým textem nebo taky kryptogramem. Sada pravidel použitých pro šifrování otevřeného textu se nazývá šifrovacím algoritmem. Operace tohoto algoritmu se běžně odvíjejí od šifrovacího klíče, který společně s textem zprávy
představuje
vstupní
informace
pro
algoritmus.
Chce-li
příjemce
z kryptogramu obdržet původní zprávu, musí použít dešifrovací algoritmus, který ve spojení s dešifrovacím klíčem převede zašifrovaný text na původní otevřený text. Každý kdo zprávu během vysílání zachytí, je označován jako odposlouchávač. Často se používají odlišná pojmenováni jako „nepřítel“, „protivník“ atp. Ačkoliv mohou odposlouchávači někdy znát dešifrovací algoritmus, valnou většinou nemají přístup k dešifrovacímu klíči. Proto je pro ně velice obtížné dostat do rukou původní otevřený text. Zatímco kryptografie je věda o vytváření šifrovacích systémů, kryptoanalýza je proces luštění původního otevřeného textu v případě, že není k dispozici příslušný klíč. Kryptologie je pak souhrnným označením pro kryptografii a kryptoanalýzu.
16
Je velice důležité si uvědomit, že útočník se nemusí k otevřenému textu dostat pouze pomocí kryptoanalýzy. Představme si, že někdo uchovává šifrovaná data na svém notebooku. Takový člověk musí sám mít přístup k dešifrovacímu klíči. Pokud si jej napíše na kus papíru a přilepí ho na notebook, tak každý kdo tento počítač ukradne, získá automaticky i dešifrovací klíč a žádnou kryptoanalýzu se vůbec nemusí zdržovat. Tímto příkladem bych rád upozornil, že k zajištění dat je potřeba mnohem více
než
dobrý
šifrovací
algoritmus.
Pro
zajištění
bezpečnosti
všech
kryptografických systémů je nejdůležitější bezpečnost jeho klíčů. V praxi se proto většině kryptoanalytických útoků soustřeďuje na zjištění dešifrovacího klíče. Pokud se to podaří, útočník má přístup ke stejným informacím jako zamýšlený příjemce zprávy a dokáže dešifrovat veškerou další komunikaci – dokud nedojde ke změně klíče. Jak vyplívá z úvodu a základních konceptů moderní kryptografie pro obdržení zprávy z kryptogramu není zapotřebí znát šifrovací klíč. Tento fakt, jenž je jedním ze zásadních poznatků studie W.Diffieho a M. Hellmana, měl výrazný dopad na podobu moderní kryptologie a vedl k rozdělení šifrovacích systémů na dvě skupiny: symetrické a asymetrické.[1]
1.6
Rozvoj kryptologie a souvislosti
Klasická kryptografie se zabývala především šiframi, tj. způsoby utajení zpráv. Patřily sem zejména šifrovací systémy jako jednoduchá záměna, jednoduchá a dvojitá transpozice, Vigenerova šifra a podobně. Často jsou nazývány jako historické šifrovací systémy. [12] Druhá světová válka přinesla nebývalý zájem o kryptografii i o kryptoanalýzu. O dříve opomíjený i zatajovaný obor se najednou začaly zajímat hlavy států a generální štáby armád. Není divu, kryptoanalytici jim přinášeli čisté informace z nejvyšších míst velení nepřítele, bez jediného výstřelu a bez rizika. Kryptoanalýza se stala tichou, neviditelnou a účinnou zbraní. Kvalitní kryptografie byla naopak obranným štítem, který umožnil dopravovat tajné zprávy jak do týlu nepřítele, tak na frontu. Nebylo to poprvé, kdy kryptografové a kryptoanalytici zasáhli přímo do bojů, aniž by opustili své kanceláře daleko od fronty. Fascinující historii kryptologie od dávné minulosti až do osmdesátých let minulého století popisuje jedinečná kniha Davida Kahna [2].
17
Ve druhé světové válce přínos kryptoanalytiků vyvrcholil. Byl tak nepřehlédnutelný a široký, že zasáhl na všech frontách a ovlivnil všechny hlavní válčící strany. Proto si po válce všechny mocnosti začaly budovat mohutná kryptografická a luštící centra, kryptografická zařízení byla zařazena do kategorie zboží dvojího užití a posuzována stejně jako vývoz tanků nebo letadel.
Obrázek 4: Budova NSA, Fort Meade, MD, USA, http://www.nsa.gov
Začalo se více dbát na rozvoj teorie. V rámci tohoto poválečného dění Claude E. Shannon nejprve v roce 1948 publikoval práci A Mathematical Theory of Communication [3], která je pokládána za základ teorie informace, a rok poté práci Communication Theory of Secrecy Systems [4], která je pokládána za základ moderní kryptologie. Není bez zajímavosti, že byla publikována díky nepozornosti vládních agentů, měla zůstat utajena. Shannon využil pojmů z teorie informace k ohodnocení bezpečnosti známých šifer. Definoval entropii jazyka, vzdálenost jednoznačnosti, dokázal absolutní bezpečnost Vernamovy šifry, zavedl pojmy difúze a konfúze a ukázal, jak posuzovat a konstruovat šifrové systémy kombinací různých typů šifer. Zavedl také model komunikačního kanálu, který se používá při popisu kryptografických systémů dodnes. Nečekané impulsy pro kryptologii přinesla počítačová revoluce v sedmdesátých letech. Nové technologické možnosti přinesly nové koncepty. Vznikly moderní blokové šifry a byl objeven princip kryptografie s veřejným klíčem [5], [6]. Ochrana dat ve státní sféře v USA si pak vynutila i vydání veřejné "státní" šifry DES [7].
18
Průmysl informačních a komunikačních technologií převrátil původní poválečný koncept co největšího zahalování kryptologie do státního aparátu. Kryptologie dostala nové impulsy a vymkla se státní kontrole. V roce 1982 se konala první veřejná mezinárodní konference kryptologů a o dvacet let později se tato věda a její aplikace probírají nejméně na dvaceti mezinárodních konferencích ročně [8]. Šifrovací technologie se dostaly do domácích počítačů, mobilních telefonů, internetu a bankovnictví. Vznikla řada nových myšlenek v kryptografii i v kryptoanalýze. Na přelomu tisíciletí byly objeveny nové principy kryptoanalýzy. Dokonce se spekuluje, že se vyrovnává potenciál tajné státní vědy a veřejné kryptologie. Na přelomu tisíciletí se také na veřejnost po 50 letech od svého vzniku dostávají odtajněné informace o luštění ve druhé světové válce. Veřejnost současně začíná postupně odhalovat skutečný cíl mohutných odposlouchávacích objektů a umístění moderních podzemních špionážních a luštících center tajných služeb. [9]
Obrázek 5: Centrum F83, rozsáhlé podzemní pracoviště systému Echelon, www.google.com
19
Po ukončení studené války v posledním desetiletí minulého století dochází k přeměně zaměření těchto center na průmyslově orientovanou špionáž. Do této pasti padají nakonec i vlastní spojenci. Navíc se projevuje mezinárodní terorismus. Na jedné straně existují snahy o omezování kryptografie z obavy z jejího zneužití teroristy a zločinci, na druhé straně je silná snaha veřejnosti o absolutní uvolnění kryptografie z důvodu ochrany vlastního soukromí. [12]
Obrázek 6: Budova luštitelské služby v Moskvě, www.google.com
20
2 Symetrické a matematické metody šifrování Symetrické šifrování také známé pod pojmem konvenční šifrování je založeno na jediném šifrovacím klíči, které musí být známo oběma zařízením – jak pro šifrování, tak pro odšifrování. V použití jednoho klíče pro šifrování i odšifrování je snad největší slabina symetrického šifrování. Nebezpečná je hlavně proto, že se nějakým způsobem musí šifrovací klíč dostat oběma stranám – té která chce informace psát a i ta co je chce číst – pro přenos šifrovacího klíče je tak potřeba použít nějaký zabezpečený přenos. Ovšem pokud takovýto přenos mezi uživateli potřebující šifrování existuje – nevzniká potřeba šifrovat odesílaná data a je možné je poslat tímto zabezpečeným přenosem. Největší výhoda symetrického šifrování spočívá v nenáročnosti na výpočetní výkon. Toto zatížení je měřitelně až 1000x menší než při šifrování asymetrickém ! ! ! Symetrické šifry se dělí na další dvě kategorie a to na šifry proudové a šifry blokové. Proudové šifry - jde o šifrování založené na bázi symetrického. Toto šifrování probíhá pomocí šifrovacího klíče postupně bit po bitu, tedy každý bit je zvláště zašifrován, a při dešifraci, je opět každý bit rozšifrován a následně složen do výchozí podoby – například souboru s dokumentem. Blokové šifry - jde o rozšířenější šifrování, které výchozí bitový sled rozdělí na bitová „slova“ a ty poté vhodně doplní bitovou šifrou, tak aby všechna slova měla shodnou velikost. V poslední době se nejvíce používá šifrování 64 bitů 128 bitů, a již se začaly objevovat služby, které vyžadují šifrování pomocí 256 bitů. [12]
2.1
Proudové šifry
Termín proudová šifra používají různí autoři rozdílným způsobem. Mnozí hovoří o slovových, případně písmenných proudových šifrách. U nich je text šifrován slovo po slovu (nebo písmeno po písmeni), přičemž pravidlo pro šifrování jednotlivých slov (písmen) se řídí jeho pozicí ve zprávě. Tato definice lze použít např. na Vigenérovu šifru nebo na jednorázovou tabulku. Nejznámějším historickým příkladem je slavná šifra Enigma. Ovšem nejčastější moderní použití termínu proudová šifra se vztahuje na šifry, u nichž je otevřený text šifrován jeden bit po druhém. Je zřejmé, že s libovolným bitem se mohou stát jenom dvě věci: buď se jeho hodnota změní nebo zůstane beze změny. Vzhledem k tomu, že bit může mít
21
jenom dvě různé hodnoty, změna bitu znamená jeho nahrazení bitem s opačnou hodnotou. Navíc platí, že změní-li se bit dvakrát, vrátí se do původního stavu.
Obrázek 7: Přístroj Enigma, www.google.com
Jestliže útočník ví, že byla použita proudová šifra, stojí před úkolem zjistit, na jakých pozicích se bity změnily a následně jim musí vrátit jejich původní hodnoty. Jestliže je v kryptogramu jednoduše patrný vzorec změněných bitů, pak má útočník poměrně snadnou práci. Polohy změněných bitů tedy musí být pro nepovolané osoby nepředvídatelné
ale oprávněný příjemce je musí (jak je tomu u šifer vždy)
identifikovat velice snadno. U proudových šifer si můžeme šifrovací proces představit jako posloupnost následujících operací: změny a ponechání původního stavu. Tuto posloupnost určuje šifrovací klíč a bývá často nazývána posloupností hesla nebo krátce heslo. Pro zjednodušení se můžeme dohodnout na tom, že 0 znamená „ponechat původní stav“ a 1 znamená „změnit“. Nyní se nacházíme ve fázi, kdy otevřený text, šifrový text i proudový klíč máme jako binární řetězce. Abychom tento popis trochu lépe objasnily, předpokládejme, že máme otevřený text 1110101 a heslo je 1000110. Protože 1 v hesle znamená, že se má bit v otevřeném textu na dané pozici změnit, vyměníme hodnotu u bitu v otevřeném textu, jenž se nachází úplně vlevo ale další bit ponecháme, tak jak je. Opakováním tohoto pravidla nám vyjde tento šifrovaný text 0110011. Již jsme se zmínili o tom, že dvojitou změnou bitu mu vrátíme jeho původní hodnotu. Z toho vyplývá, že dešifrovací proces je shodný se šifrovacím, heslo tedy slouží i dešifrování.
22
Ve výše uvedeném postupu jsme kombinovali dvě binární sekvence a vznikla nám sekvence třetí. Řídili jsme se přitom pravidlem, jenž šlo v našem případě definovat jako „je-li na nějaké pozici ve druhém řetězci 1, poté je nutné změnit bit na odpovídajícím místě v řetězci prvním“. Existuje mnoho oblastí pro, něž jsou proudové šifry takřka optimálním řešením. Jedním z důvodů je, že pokud dojde k nesprávnému příjmu některého bitu šifrovaného textu, definuje se špatně pouze tento jeden bit, protože každý bit otevřeného textu je určen jen jedním bitem textu šifrového. Touto vlastností se proudové šifra liší od šifer blokových, kde má jeden špatně přijatý bit za následek špatné definování celého bloku. Tato vlastnost „malé propagace chyby“ dešifrovacím algoritmem je nezbytná, pokud je šifrový text vysílán po kanálu s vysokou hladinou šumu. Proto se proudové šifry používají například pro šifrování digitalizované řeči na mobilních sítích GSM. Další výhodou proudových šifer oproti blokovým je rychlost a nenáročná implementace. [1] • FISH • RC4 - (Rivest Cipher 4) Klíč má proměnlivou délku. šifra je streamová - nemá jednoznačně určenou délku bloku. Kromě problému s bezpečným předáním klíče, je toto šifrování nebezpečné také tím, že používaný klíč je bezpečný do té doby, dokud jej nemá ještě někdo jiný – v nejhorším případě například stovky osob. A pokud bychom chtěli mít pro každou komunikaci jiný klíč musíme mít klíčů opravdu hodně. [12]
23
2.2
Blokové šifry
U blokových šifer je bitový řetězec rozdělen do bloků o pevné délce. Šifrovací algoritmus se aplikuje přímo na takovýto blok, čímž vznikne blok kryptogramu, jehož velikost je stejná. (Alespoň u většiny symetrických šifer) Blokové šifry mají širokou škálu využití. Dokáží nabídnout vysokou míru zabezpečení, integritu dat či ověření uživatele a dokonce mohou složit jako generátory hesel pro proudové šifry. Ovšem stejně jako u proudových šifer se zde jen obtížně stanovuje přesná míra zabezpečení. Horní hranici kryptografické síly algoritmu určuje velikost klíče. Již u jednoduchých substitučních šifer jsme ale zjistili, že vysoký počet klíčů není žádnou zárukou skutečné síly. Jestliže je u symetrických algoritmů nejjednodušším typem útoku, útok hrubou silou, říkáme o nich, že jsou dobře navržené. Ovšem jestliže je počet klíčů příliš nízký, může být algoritmus navržen dobře a přesto jej půjde snadno prolomit. Navrhování silných šifrovacích algoritmů je velice specializovaná činnost. Přesto existuje několik zásadních prvků, které by měla každá silná bloková šifra mít. Jestliže útočník získal odpovídající dvojici otevřeného a šifrového textu a nezná klíč, neměl by mít možnost snadno odvodit, který šifrový text odpovídá danému bloku textu otevřeného. Algoritmus, jehož výsledkem je předvídatelná změna v šifrovém textu, tuto podmínku například nesplňuje. To je jedním z důvodů proč by měli mít blokové šifry tzv. vlastnost difúze, což znamená, že i malá změna v otevřeném textu – například na jedné či dvou pozicích – má za následek nepředvídatelné změny v šifrovém textu. Pokud útočník použije útok silou je možné, že během takovéhoto hledání vyzkouší klíč, který se od toho správného liší jen na několika málo pozicích. Pokud by útočníkovy cokoliv naznačilo, že použil například klíč, který se od původního řetězce lišil jenom na jediné pozici, přestal by s kompletním vyhledáváním a místo toho by jen u tohoto klíče zkoušel měnit jednu pozici po druhé. To by výrazně snížilo čas potřebný pro hledání klíče. Což je další věc, kterou si rozhodně nepřejeme. Součástí blokové šifry by tedy měla být i vlastnost konfúze, jež lze shrnout jako požadavek, aby útočníkovi při hledání klíče nic nenaznačovalo, že už „přihořívá“. Pokud útočník může zjišťovat jednotlivé části klíče bez ohledu na jeho zbytek, říkáme, že provádí útok „rozděl a panuj“. Aby něco takového nebylo možné,
24
vyžadujeme po šifře „úplnost“, teda aby se každá část šifrovaného textu nějak odvíjela od každé části klíče. Významnou součástí procesu vyhodnocováni blokových šifer je kromě zmíněných tří je i statistické testování. To ostatně hraje roli při analýze všech symetrických šifer. Nejjednodušším a pravděpodobně také nejpřirozenějším způsobem použití blokové šifry na dlouhou zprávu je rozdělení binární sekvence do bloků o příslušné délce a následné samostatné šifrování každého bloku nezávisle na ostatních. V takovém případě říkáme, že je používán mód elektronické kódové knihy neboli ECB. Jestliže je zvolen klíč a vy se rozhodnete pro použití módu ECB, budou poté shodné bloky původní zprávy zašifrovány do shodných bloků kryptogramu. Nebezpečí hrozí, jestliže útočník získá odpovídající dvojici šifrového textu a otevřeného textu, dokáže pak najít ve zprávě tentýž blok otevřeného textu jednoduše tím, že vyhledá známý blok textu šifrového. Z tohoto pohledu se mu rozhodně vyplatí obětovat trochu času a vybudovat si slovník známých dvojic bloků otevřeného a šifrového textu. Navíc je zřejmé, že jestliže se ve zprávě objevuje jeden a tentýž blok, promítnou se tyto bloky i do výsledného kryptogramu. To je jedním z důvodů proč bychom měli používat poměrně velké bloky, například po čtyřiašedesáti bitech, což odpovídá osmi písmenům. Použití ECB má ještě jednu možnou nevýhodu, kterou si ukážeme na následujícím příkladu.[1] Představme si, že k zašifrování zprávy The price is four thousand pounds. Byla použita neznámá bloková šifra s neznámým klíčem. Víme jen to, že se zpráva skládá ze dvoupísmenných bloků, že mezery a interpunkce byly odstraněny a kryptogram zní: C1,C2,C3,C4,C5,C6,C7,C8,C9,C10,C11,C12,C13,C14. Předpokládejme, že útočník zprávu zná. V takovém případě si snadno odvodí, že C1 zastupuje th, C2 zastupuje ep, atd. Poté upraví zprávu tak, že ji poskládá jen do bloků: C1,C2,C3,C4,C5,C6,C7,C12,C13,C14. Příjemce použije na kryptogram dešifrovací algoritmus se správným klíčem a získá zprávu The price is four pounds. Protože dešifrování proběhlo v pořádku a zpráva dává smysl, nemá příjemce žádný důvod pojmout podezření, že bylo s kryptogramem manipulováno. A tak se domnívá, že uvedená cena je správná.
25
Všem těmto potencionálním rizikům vyplývajícím z blokových šifer v ECB módu lze předejít tím, že při šifrování bude každý blok nějakým způsobem provázaný s blokem předešlým. V takovém případě vzniknou ze stejných bloků otevřeného textu jiné bloky textu šifrového a manipulace s kryptogramem bude mít za následek, že zpráva po dešifrování nebude dávat smysl. Lze toho docílit dvěma běžnými způsoby. Říká se jí zpětná vazba (cipher feed-back, mód CFB) a řetězení šifrových bloků (cipher block chaining, mód CBC). [1]
2.2.1 Typy blokových šifer •
AES – (Advanced Encryption Standard) – Vytvořila ji americká vláda za účelem šifrování svých dokumentů Velikost klíče může být 128, 192 nebo 256 bitů – prozatím nebyla prolomena.
•
Blowfish - Šifra je dílem B. Schneierem a poprvé byla zveřejněna roku 1994. jde o šifru s velikostí bloku 64 bitů a délkou klíče nejvýše 448b (tj. 56B). Autor tuto šifru vytvořil jako neplacenou nelicencovanou alternativu k DES, avšak na rozdíl od DES, dodnes nebyla prolomena.
•
DES – byla vyvinuta v sedmdesátých letech a je považována za nedostatečnou neboť používá pouze 56 bitů pro šifrování – šifru je metodou brute force možné rozlousknout přibližně za 24 hodin standardním počítačem dnešní doby.
•
Triple DES – rozšířená verze nejpoužívanější 3TDES – používá klíč o délce 168 bitů je tak bezpečnější než klasický DES, avšak taky o dost pomalejší – více než AES 256 bitů
•
GOST - Šifra používající 64-bitový blok a 256-bitový klíč. Navržena v Sovětském Svazu.
•
IDEA - šifra používající bloky o 64 bitech a 128-bitový klíč. Považována za jeden z nejsilnějších algoritmů. Patentovaná do roku 2010 – 2011. Jde o jednu z nejlepších šifer.
•
RC2 - ( Rivest Cipher 2 ) šifra o délce bloku 64-bitů, klíč má proměnlivou délku. Obchodní tajemství RSA, SDI.
26
•
RC5 ( Rivest Cipher 5 ) Bloková šifra s množstvím argumentů jako délka bloku, délka klíče nebo počet iterací šifrování nad jedněmi daty.[12]
2.3
Používání symetrických algoritmů k autentizaci a ověření integrity dat
Autentizace a ověření integrity dat lze docílit i pomocí symetrické kryptografie. Existují dva druhy autentizace: jednosměrná, kdy se jeden uživatel prokazuje druhému, a oboustranná autentizace, při které se oba uživatelé prokazují sobě navzájem. Příkladem jednostranné autentizace je používání magnetických karet v bankomatech. Bankomat kartu kryptograficky ověří za použití vašeho PIN. Majitel karty se ovšem musí při ověřování pravosti bankomatu spoléhat na nekryptografické prostředky, jako je například jeho poloha a design. Dalším příkladem jednostranné autentizace je přihlašován do počítače. K autentizaci dojde správným použitím klíče v algoritmu. Tento systém spoléhá na to, že nebude nikomu prozrazen. Integrity dat ve zprávě lze docílit pomocí autentizačního algoritmu a tajného klíče. Autentizační algoritmus přijme jako vstupní data zprávu a smluvený klíč a následně vypočítá jako výstup autentizací hodnotu. Ta je krátkým bitovým řetězcem, jehož hodnota se odvíjí od použitého autentizačního algoritmu zprávy a smluveného klíče.
Obrázek 8: Ověřování za pomoci symetrické autentizace
Pokud chce uživatel A poslat zprávu uživateli B, přiloží ke zprávě autentizací hodnotu. B přijme zprávu i autentizací hodnotu. Poté spočítá výstup autentizačního algoritmu, jehož výstupem bude zpráva od uživatele A a smluvený tajný klíč. Jestliže
27
je tento výstup shodný s autentizační hodnotou, kterou poslal A, bude mít B jistotu, že zprávu od A nikdo nezměnil. Funkce tedy ověřuje, jak integritu dat, tak i totožnost. Důležitým aspektem tohoto autentizačního procesu je, že odesilatel i příjemce provádějí přesně ty samé propočty. Proto si musejí A i B navzájem důvěřovat. Sdílejí stejný klíč a spoléhají se na to, že pozměňování obsahu zprávy předejdou uchováváním tohoto klíče v tajnosti. Nehledají ochranu jeden před druhým. [1]
28
3 Asymetrické metody šifrování Jako takové vzniklo v roce 1975 díky dvou lidem, kteří ji vyvinuli a to Whitfield Diff a Martin Hellman. Asymetrické šifrování využívá dvojice klíčů a to veřejný a soukromý. Veřejný jak už z jeho názvu vyplývá je přístupný všem, dále soukromý je dostupný jen tomu, kdo má právo šifrovanou zprávu odšifrovat. Tyto klíče je třeba vygenerovat na začátku komunikace. Veřejný umístím buďto na server dostupný lidem, kteří tento klíč budou používat pro šifrování anebo jej poslat přímo těmto lidem, některou z dostupných elektronických cest. Hlavní výhodou asymetrického šifrování je, že klíče soukromé jsou dostupné pouze majitelům těchto klíčů. Za nejvýznamnější systémy jmenujme tři zástupce - Elgamal (autorem Tahela Elgamala), RSA (Autory - Ron Rivest, Adi Shamir, Leonard Adleman, DiffieHellman) a nakonec DSA (Digital Signature Algorithm jehož autorem je David Kravitz)[12] Odesilatel posílající příjemci zprávu (šifrovaně) si vyžádá Váš veřejný šifrovací klíč, tímto zprávu zašifruje, a takto zašifrovanou ji pošle Vám. Vy jakožto jediný vlastník svého privátního klíče zprávu odšifrujete – ale nikdo jiný s jiným šifrovacím privátním klíčem již ne – pokud se o to pokusí – vypadne mu po dešifrování holý nesmysl ve formě nespecifikovaného shluku znaků. Šifrovací metoda RSA je zatím jedna z nejrozšířenějších, používá Fermatovu větu a modulární aritmetiku. Jde o část matematiky, která se zabývá zbytky po dělení celých čísel. Síla této šifry spočívá v tom, že dosud nebyla objevena metoda, jak rozložit velká čísla na prvočísla - faktorizace. V danou chvíli není ani zcela jisté zda je vůbec možné takovouto metodu objevit. Pokud se tak ovšem stane, bude tato šifra nepoužitelná. Základní myšlenkou kryptografických systémů veřejných klíčů je, že každá zúčastněná strana má veřejný klíč a odpovídající soukromý klíč. Ty jsou zvoleny tak, aby odvození soukromého klíče z klíče veřejného bylo prakticky nemožné. U systémů veřejných klíčů jsou algoritmus i šifrovací klíče veřejné. Útočník tedy stojí před úkolem dešifrovat zprávu z kryptogramu vytvořeného metodou, kterou zná. Šifrovací proces tedy musí být zvolen velice pečlivě, aby to útočník neměl nijak snadné. Současně ovšem nesmíme zapomínat na to, že dešifrování musí být pro
29
oprávněného příjemce jednoduché. Celý proces tím pádem musí být nastaven tak, aby k získání zprávy z kryptogramu postačovala znalost dešifrovacího klíče. Takovýto koncept je náročný a nikterak samozřejmý. Častá otázka zní: „Jestliže každý ví, jakým způsobem jsem dostal kryptogram, co brání v tom, aby z něj dostali původní zprávu?“ Odpověď nám dá následující nematematický příklad. Představme si, že jsme v zavřené místnosti bez telefonní linky a dostanete pražský telefonní seznam. Když Vám pak někdo dá jméno a adresu a chce zjistit telefonní číslo je náš úkol jednoduchý. Ovšem jestliže dostanete náhodně zvolené telefonní číslo a my k němu máme dohledat jméno a adresu, pak se máme co otáčet. Problém není v tom, že by jsme nevěděli, co dělat. Teoreticky můžeme začít na první stránce a číst jedno číslo za druhým tak dlouho, dokud nenarazíte na to pravé. Jenže háček vězí v tom obrovském množství námahy, jež je s tím spojeno. Představíme-li si tedy zprávu jako „jméno a adresu“, kryptogram jako „telefonní číslo“ a dešifrovací proces jako „najdi správné číslo“, pak se nám zadání původního úkolu – alespoň pro pražský telefonní seznam – splnit podařilo. Většina v praxi využívaných algoritmů s veřejnými klíči jsou blokové šifry, jež se zprávou zacházejí jako se zprávou složenou z velkých celých čísel, přičemž bezpečnost jim zaručuje obtížnost řešení daného matematického problému. Nejznámější šifrou se už výše popsaná šifra RSA. Matematickým problémem spojeným s šifrou RSA je rozklad na prvočinitele. Máme veřejně známé číslo N, jež je násobkem dvou prvočísel, která jsou tajná. Tato čísla jsou velice důležitá, protože ten, kdo je zná, může s jejich pomocí vypočítat z veřejného klíče klíč soukromý. Číslo N, jež určuje velikost bloku zprávy, tedy musí být dost velké na to, aby je útočník nedokázal rozložit na příslušná prvočísla. Jestliže by toto N bylo malé, dokázal by rozklad provést kdokoliv. Velice snadným příkladem může být N =15, kde jsou prvočísly 3 a5. Obecně se však má za to, že jestliže je N dostatečně velké je hledání prvočísel prakticky nemožné. Číslo N určuje velikost bloku i klíče. Z toho vyplívá, že velikost bloků i klíčů bývá mnohem větší, než je tomu u symetrických šifer. Zatímco u těch je běžná velikost bloku 64 nebo 128 bitů, u RSA narazíte minimálně na bloky o velikosti 640 bitů a žádnou výjimkou nejsou ani bloky s 1024 nebo 2048 bity. Dalším důsledkem je, že šifrovací i dešifrovací procesy zahrnují mnoho výpočtů s velkými čísly. Jsou proto o poznání pomalejší,
30
než je tomu u symetrických šifer. Jen zřídka se tedy používají k šifrování velkých objemů dat, ale nacházejí uplatnění spíš pro digitální podpisy nebo pro šifrování klíčů symetrických algoritmů, aby je bylo možné následně bez obav distribuovat nebo ukládat. Dalším široce rozšířeným algoritmem veřejných klíčů je El-Gamal, který je základem amerického standardu pro digitální podpisy (DSS). U systému El Gamal, jsou velikosti klíčů obdobné jako u RSA, ale jeho bezpečnost se odvíjí od obtížnosti jiného matematického problému, známého jako diskrétní logaritmus. El Gamal však má jisté vlastnosti, kvůli kterým se pro šifrování jako takové příliš nehodí. [1]
3.1
Útoky na systémy s veřejnými klíči
U asymetrických algoritmů jsou klíče delší než u algoritmů symetrických. To ovšem ještě neznamená, že asymetrické algoritmy musejí být zákonitě silnější. Nebývají totiž napadány útoky hrubou silou, protože je jednodušší se zaměřit na útok na matematický problém, na němž je algoritmus postaven. Například u RSA je snazší najít dělitele pro modulo N, než vyzkoušet všechny možné dešifrovací klíče. Abychom si ukázali, jak současný vývoj v matematice ovlivnil kryptografii veřejných klíčů, soustředíme se na RSA a rozklad na prvočinitele. Podobně bychom se ovšem mohli podívat i na jiné systémy veřejných klíčů, jež jsou vystaveny na jiném matematickém problému. Zpracování rozkladu na prvočinitele (faktorizace) prošlo během posledních 30 let ohromným vývojem. Vděčí za to pokroku jak na poli teoretickém, tak na poli technologickém. V roce 1970 bylo rozloženo na dvě prvočísla devětatřiceticiferné číslo (2128+1). V té době byl podobný počin považován za něco úžasného. Když byla roku 1978 poprvé publikována šifra RSA, byla jako součást studie zveřejněna i soutěž o rozklad 128 ciferného čísla, přičemž vypsaná odměna měla hodnotu 100 dolarů. Jednalo se první takto navrženou odměnu – podobných projektů byla později celá řada. Požadované číslo bylo rozloženo na činitele až roku 1994, kdy se do práce zapojila celosvětová počítačová síť. Při rozhodování o délce klíčů pro RSA je nutné vzít v potaz nejen Moorův zákon, ale také možný vývoj faktorizačních technik. Moorův zákon říká, že každých 18 měsíců se výkon počítačů zdvojnásobí, aniž by se nějak změnila jejich cena. Pro ilustraci můžeme uvést dramatický dopad nové matematické metody známé jako obecné síto
31
číselných polí (GNFS) publikované roku 1993. Díky této metodě bylo možné zdroje určené pro rozklad čísla o určité velikosti využít k faktorizaci výrazně větších čísel. Například zdroje, jež byly dříve zapotřebí pro rozklad čísla o 150 cifrách, nyní stačí k rozkladu čísla o skoro 180 cifrách. Tento pokrok v matematice výrazně převyšuje vliv technologického vývoje předpovídaného pro mnoho let dopředu. Díky této metodě bylo roku 1999 rozloženo 155 ciferné číslo RSA-512. Faktorizace trvala méně než 8 měsíců a opět se na ní podílela celosvětová počítačová síť. Pro ilustraci matematické složitosti tohoto problému uveďme, že v závěrečné fázi byla řešena soustava šesti miliónů rovnic! Následovala soutěž publikovaná v Knize kódů a šifer, ve které šlo také o faktorizaci 512bitového modula. Tyto rozklady na činitele mají velký význam, protože modula této velikosti (155 cifer či 512 bitů) byla ještě před několika lety běžně používaná v kryptografii veřejných klíčů. V současné době se doporučuje, aby se velikost modula RSA pohybovala v rozmezí 640 – 2048 bitů v závislosti na potřebném stupni zabezpečení. Číslo o 2048 bitech má v desítkové soustavě 617 cifer. Abych demonstroval o jak ohromné číslo se jedná přikládám číslo o uvedené velikosti. Sláva a peněžní výhra v hodnotě 200 000 dolarů čekají na toho, kdo jako první dokáže rozložit na prvočíselné činitele např. číslo: 25195910236225489788452130212365966985474120023154812917541895162458 91023032178902305148956230154785489562312222003204080090788485598352 51489785589526659845784522125587896231012365478952336598477894100023 06059850147949569879452156311647894562123015489547859595455505120605 98502147878925195910236225482519591023622548978845213021236596698547 41200231548129175418951624589102303217890230514895623015478548956231 22220032040800907884855983525148978558952665984578452212558789623101 23654789523365984778941000230605985014794956987945215631164789456212 30154895478595954555051206059850214787892519591023622548123659800187 73740
Jak jsem se už zmiňoval o útocích hrubou silou, rád bych zmínil možný vliv kvantových počítačů. Ačkoliv by kvůli nim jistě muselo dojít k dramatickému nárůstu délky symetrických klíčů, těžko si představit, že by se tomu kryptografie nepřizpůsobila a, že by se symetrické algoritmy přestaly používat. U veřejných klíčů
32
by situace mohly být jiná. Pro tyto systémy by totiž kvantové počítače představovali mnohem větší hrozbu. Například rozklad na prvočinitele by byl o poznání jednodušší. Naštěstí ani největší nadšenci pro kvantové počítače nepředpokládají, že by se tyto počítače začali šířeji používat dříve než za 20 let. [1],[12]
3.2
Hashovací funkce
Kryptografie je často používána i v oblastech, kde není požadována schopnost odvodit znění původní zprávy z jejího zašifrovaného tvaru. Dokonce se může vyskytnout i požadavek, aby něco takového bylo nemožné. Jako příklad může sloužit třeba ukládání hesla v počítači. Je-li heslo někde v počítači uloženo, konkrétně třeba v databázi sloužící pro ověření identity uživatele, musí být použit nějaký druh ochrany. Základním požadavkem je pak v tomto případě zjistit, zda bylo heslo při přihlašování zadáno správně. Už však není zapotřebí získat z databáze samotné znění tohoto hesla. Kryptografie je také často používána v případech, kdy je zapotřebí zhustit dlouhou zprávu do krátkého řetězce. V takových případech se nelze vyhnout tomu, aby více takovýchto zpráv nemělo stejný ekvivalent v podobě kratšího bitového řetězce. Z toho přímo vyplívá, že zmíněný proces je nevratný. Těmto funkcím se říká hashovaní funkce a v závislosti na konkrétním typu použití mohou či nemusejí používat kryptografické klíče. Základní princip hashovacích funkcí spočívá v tom, že výsledná hashovaní funkce je zhuštěným otiskem, který zastupuje původní zprávu. Hashovacím hodnotám se říká různě, například digitální otisk nebo prostě hash. Hashování nachází spoustu různých uplatnění, například při kontrole integrity dat nebo jako součást schémat digitálního podpisu. Obecně řečeno, hashovaní funkce přijímají vstupní dat o libovolné délce, ale výstupem je řetězec o délce pevně stanovené. Jestliže se objeví dva vstupy, jejichž výstup je stejný, došlo k takzvané kolizi. Existence kolizí je nevyhnutelná. Chceme-li tedy jednoznačně identifikovat zprávu pomocí jejího digitálního otisku, musíme hashovaní funkci zvolit velice rozvážně.
33
3.3
Digitální podpisy
Používání asymetrických algoritmů bývá v praxi omezeno na ochranu symetrických klíčů a na zajišťování digitálních podpisů. Jestliže je zapotřebí řešit také rozpory mezi odesilatelem a příjemcem ohledně obsahu zprávy nebo jejího původu, pak nám symetrická kryptografie nemůže postačovat. Je nutné Použít digitální podpis. Digitální podpis zprávy od odesilatele je kryptografický řetězec, jehož hodnota se odvíjí jak od obsahu zprávy, tak od samotné osoby odesilatele. Oproti tomu běžný podpis je vázán jen na osobu odesilatele a je pro každou zprávu stejný. Digitální podpis zajišťuje integritu dat a zároveň je i nezpochybnitelným důkazem původu zprávy. Příjemce si jej může nechat, jako důkaz pro případné urovnání následných sporů, například pokud by odesilatel chtěl popřít obsah zprávy nebo to, že ji vůbec poslal. Právě tato schopnost rozhodovat spory mezi odesilatelem a příjemcem je hlavním rozdílem mezi digitálním podpisem a procesem symetrické autentizace, který jsem zmiňoval výše. Asymetrické kryptosystémy představují pro digitální podpisy naprosto ideální řešení. Základní princip digitálních podpisů založených na systémech veřejných klíčů, jako je například RSA nebo El-Gamal, je velice prostý. Každý uživatel má vlastní soukromí klíč, který může používat výhradně on sám a jeho použití jej tedy jednoznačně identifikuje. Navíc zde ovšem existuje ještě odpovídající veřejný klíč. Každý kdo jej zná, si může ověřit, že byl použit odpovídající soukromí klíč, ale jeho podobu již nezjistí. Informace, že byl použit soukromí klíč, dává příjemci jistotu jak o původu zprávy, tak i o bezpečnosti jejího obsahu. Odesilatel zároveň nemusí mít obavy z toho, že by jeho soukromí klíč (neboli podpisový klíč) někdo s pomocí veřejného (neboli ověřovacího) klíče napodobil.
34
Obrázek 9: Digitální podpisy
Zpracování asymetrické kryptografie je velice náročné na výpočetní kapacitu. Proto je pomocí hashovaní funkce obsah zkrácen do zredukované (hashovaní) podoby. Podpis pak vzniká z hashe (jenž představuje obsah zprávy) požitím asymetrického algoritmu se soukromím klíčem. Podpis tedy může vytvořit pouze majitel soukromého klíče, ale ověřit jej může každý, kdo zná odpovídající klíč veřejný. Pro tento účel vznikne prostřednictvím asymetrického algoritmu s veřejným klíčem z podpisu hodnota. Ta by měla být hashovacím kódem zprávy, jejž si může spočítat naprosto kdokoliv. Pokud je tato hodnota shodná s hashem, je podpis přijat jako pravý. Jsou-li rozdílné, je podpis falešný. [1],[12]
35
4 Kvantová kryptografie Zatímco v klasické kryptografii se používají nejrůznější matematické metody, aby se útočníkům zamezilo zjištění obsahu přenášené zprávy, kvantová kryptografie k tomu používá zákony fyziky, konkrétně kvantové chování jednotlivých fotonů světla. To zajišťuje, že informace přenášená fotony se při jakémkoli odposlechu změní a jakýkoli útok pak lze snadno detekovat. Úspěšný odposlech přitom útočníkovi neposkytne dostatek informací pro efektivní narušení bezpečnosti. Kvantová kryptografie se proto výhodně používá pro distribuci klíčů, neboť tok jednotlivých fotonů umožňuje spolehlivé a bezpečné vytvoření tajného klíče mezi dvěma stranami. „Kvantovost“ kvantové kryptografie spočívá ve způsobu přenosu klíče. Jako abeceda pro přenos klíče se používá kvantových stavů jedné částice (například fotonu). Jakýkoliv pokus o odposlech ovlivní podstatným způsobem stav částí, a může být proto odhalen. Pokud je zjištěn odposlech, klíč se prostě nepoužije. Odesílatele budeme označovat jako Alice a příjemce Bob. Alice a Bod si chtějí vyměnit tajný klíč prostřednictvím přenosového kanálu, který může být dostupný k odposlechu třetí osobou, která bývá označována jako Eva (podle anglického slova „eavesdropper“ = tajně naslouchající). Klíč je reprezentován bitovým řetězcem, posloupností nul a jedniček. Možná varianta kvantové kryptografie používá lineárně polarizované fotony a jeho schéma je na prvním obrázku. Binární znaky budou 0 a 1 budou kódovány do dvou stavů fotonů se vzájemně kolmými polarizacemi. Alice a Bob se musí domluvit, jaké směry polarizace zvolí, tedy jaké použijí polarizační báze. Pokud tomu tak je, potom je chování fotonů na polarizačním hranolu jednoznačné. Fotony, které jsou polarizovány v jednom směru, jsou odkloněny na jiný detektor, než ty, co jsou polarizovány ve směru na něj kolmém. Pokud by polarizační báze byli odlišné, byl by foton odkloněn náhodně na první či druhý detektor.
36
Obrázek 10: – schéma kvantového přenosu informace
Pokud by Eva chtěla provést odposlech, nemůže to být odposlech pasivní, ale musí stejně jako Bob změřit polarizaci přicházejícího fotonu, a navíc poslat stejně polarizovaný foton Bobovi. Eva ale neví, jakou polarizační bázi Alice a Bob používají. Pokud použije odlišnou bázi, vnese do komunikace s určitou pravděpodobností chybu, a pokud Alice a Bob své měření porovnají, mohou zjistit, že jsou odposloucháváni. Co když ale Eva používá správnou polarizační bázi (třeba náhodou)? To by pak zůstala neodhalena. Proto musí Alice a Bob na sobě nezávisle a náhodně měnit polarizační bázi (buď + nebo ×). Po přenosu si veřejným kanálem vymění informaci, v jakých polarizačních bázích, kdy pracovali, a ponechají si jen ty bity, pro než použili stejné báze (jen mohly být správně detekovány). Postup: 1. Alice a Bob se dohodnou, které dvě polarizační báze (vzájemně otočené o 45˚) a na tom, co bude znamenat jedničku a co nulu. 2. Alice pak generuje náhodné bity pro klíč a náhodně volí polarizační báze, Bob také volí náhodně polarizační báze nezávisle. 3. Pak si sdělí (pomocným komunikačním kanálem), které polarizační báze používali (jen báze, ne konkrétní polarizace) a ponechají si bity, pro které použili stejné báze. Nejdříve Bob pošle Alici své báze a ona mu pošle, které byly zvoleny stejně. 4. Bob vybere náhodně některé bity a ty obětuje k odhalení Evy. Pošle je Alici, která potvrdí, zda je má stejné. Pokud by Eva poslouchala, nastane odchylka. 5. Zbylé bity tvoří klíč. Jedinou slabinou je komunikace po veřejném kanále. Aby se Eva nemohla vydávat Alici za Boba a naopak, je potřeba provést autentizaci. K tomu potřebují na začátku jisté malé množství tajných informací, které slouží jako počáteční heslo. Toto heslo
37
se bude pro každou novou komunikaci nahrazovat novým, získaným z části přeneseného klíče. Myšlenka využít zákony kvantové mechaniky v kryptografii se poprvé objevila v sedmdesátých letech u Stephena Wiesnera, ale publikována byla až v roce 1983. První použitelné schéma vytvořili Charles Bennet a Gilles Brassard. Je to schéma, co bylo vyloženo v tomto textu a je označováno podle jmen autorů jako BB84. První pokus uskutečnili v roce 1989. V tomto pokusu byla vzdálenost mezi příjemcem a odesílatelem pouze 32 cm. Od té doby prodělává tato metoda bouřlivý vývoj a byly vykonány pokusy s optickými vlákny na vzdálenosti desítek kilometrů. Jedinou špatnou vlastností je dosahovaná přenosová rychlost, která činí pouze jednotky až desítky bitů za sekundu. V naší republice se podobné zařízení nachází v Olomouci na pracovišti Univerzity Palackého a Fyzikálního ústavu Akademie věd. Tento pouze laboratorní přístroj nepoužívá kódování pomocí polarizačních stavů fotonu, ale fázové kódování. Místo měnění dvou polarizačních bází, mění Alice a Bob pro každý foton vzdálenost svého ramene interferometru. Vše ostatní je stejné, jak bylo popsáno. Jako kvantový kanál bylo použito optické vlákno, po němž se posílaly zeslabené světelné pulzy generované polovodičovým laserem. Toto vlákno bylo dlouhé pět set metrů. [13],[14]
4.1
Systém kvantové kryptografie
Kvantová kryptografie (quantum cryptography) a quantum computing jsou nové oblasti kvantové mechaniky, které se odehrávají v tzv. Hilbertově prostoru (podle německého matematika Davida Hilberta), kde se subatomické částice vlastně nikdy nenacházejí v konkrétním místě. Kvantové počítače mohou v budoucnu hrát významnou roli v šifrování a mohou také nahradit superpočítače. Systém kvantové kryptografie je ve skutečnosti systém distribuce klíče (QKD, Quantm-Key Distribution), který váže bezpečnost systému na princip nejistoty kvantové mechaniky. Základem principu nejistoty (Heisenbergův princip) je, že měření prováděné na fyzickém systému pro získávání nějakých informací o daném systému bude mít nutně na systém nějaký vliv, byť velice malý. Systém kvantové kryptografie je navržen tak, že odesílatel (Alice) připraví fyzický systém do známého kvantového stavu a pošle ho oprávněnému příjemci (Bob). Bob
38
provede měření jedné ze dvou určitých veličin (principy kvantové fyziky neumožňují měření obou veličin současně) systému přijatého od Alice. Těchto výměn a měření se provede dostatečné množství a v ideálním případě pak budou mít obě strany komunikace dostatek hodnot, které mohou sloužit jako klíč. Kvantový systém, který se běžně používá, jsou jednotlivé fotony, tedy částice světla. Každý foton nese jeden bit kvantové informace a označuje se jako qubit (quantum bit). Kromě fotonů by šlo sice použít i jiný kvantový systém, ale světlo se šíří velmi rychle a snadno, a navíc znalosti manipulace s ním jsou v dostatečně pokročilém stádiu. Jednotlivé fotony lze vysílat jak optickým kabelem, tak vzduchem, i když v druhém případě je realizace kvůli atmosférickému prostředí poněkud složitější. Jako veličina pro měření se nejčastěji používá polarizace fotonů (viz obrázek). V roce 1984 poprvé popsali takový bezpečný kvantový systém distribuce klíče pánové Charles Bennett a Gilles Brassard (BB84). Jako alternativa se používá metoda korelovaných (entangled) stavů, kterou poprvé navrhl pro kvantový systém Artur K. Ekert v roce 1990. [16] Informace o veličině, kterou Alice nastavila a Bob měřil, byly vlastně veřejné, ale konkrétní naměřené hodnoty se nikdy nesdělovaly. Takže potenciální útočník by musel zkoušet získávat nějaké informace z kvantového systému, který Alice poslala Bobovi. To by se ovšem kvůli principu nejistoty odrazilo na samotném systému. Došlo by k naměření jiné hodnoty než nastavené odesílatelem, takže komunikující strany by se o zlomyslném odposlechu dozvěděly prostým porovnáním příslušných hodnot. Podle objemu informací, které se útočník takto mohl z výměny mezi Alicí a Bobem dozvědět, je pak před ustavením samotného klíče proveden ještě proces destilace bitů (bit distillation) a zesílení soukromí (privacy amplification). [11],[13],[14]
39
4.2
Jak pracuje kvantová distribuce klíčů
Kvantový (fotonový) systém distribuce klíče umožní Alici a Bobovy získat sdílený klíč. Alice vysílá fotony v jedné ze čtyř polarizací: 0, 45, 90 nebo 135 stupňů. Bob ve svém přijímači měří polarizaci buď v kolmé (0 a 90 stupňů), nebo diagonální bázi (45 a 135 stupňů). Vlastní distribuce klíče probíhá v několika krocích. Alice vysílá fotony náhodně v některé ze čtyř polarizací.
Pro každý přijatý foton si Bob zvolí náhodný typ měření, buď podle kolmé (+), nebo diagonální báze (X).
Výsledky měření si Bob pro sebe zaznamená.
Po dokončení přenosu Bob sdělí Alici, jaké typy měření se pro jednotlivé přijaté fotony použily (samotné výsledky měření si ale samozřejmě ponechá pro sebe) a Alice mu sdělí, které typy měření pro jednotlivé fotony byly správné. Tato informace při odposlechu případnému útočníkovi nic neřekne.
Alice a Bob si pak ponechají ty výsledky měření, kde se měřila polarizace správně. Tyto případy si převedou na bity (0 nebo 1) a jejich posloupnost bude definovat samotný klíč.
BENNETT, Charles; BRASSARD, Gilles; EKERT, Arthur, Quantum Cryptography [11]
40
4.3
Praktické použití kvantové kryptografie
Kvantová kryptografie se pomalu přesunuje z laboratorního prostředí do praktického využití pro zajištění maximální bezpečnosti. Nejobtížnější je navrhnout a vybudovat systém vysílače (vhodného pro danou metodu kvantového systému) a přijímače (detektoru) jediného fotonu pro běžné použití, tedy pro spolehlivé překonání dostatečné vzdálenosti. V 80. letech laboratoř v IBM T. J. Watsonově výzkumném středisku použila kvantový systém na vzdálenost pouhých 30 centimetů s rychlostí 10 bit/s. Od té doby ale uplynulo hodně vody, vyvinuly se nové zdroje fotonů, fotodetektory a lepší optická vlákna, což vše samozřejmě dovoluje řádově vyšší rychlosti budování klíčů (tisíce bitů za vteřinu) i větší vzdálenosti (desítky kilometrů), protože světlo s vyšší vzdáleností podléhá útlumu a rozptýlené fotony lze již jen obtížně zachytit. Kvantová kryptografie se pomalu propracovává ke skutečně komerčnímu využití, tak se podívejme, s čím konkrétně se můžeme na trhu již setkat. Švýcarská společnost id Quantique před několika lety dosáhla fungování systému na vzdálenost 67 kilometrů a japonská Toshiba před nedávnem oznámila úspěch i na 100 kilometrů po optickém vláknu. Pro větší vzdálenosti se pracuje na kvantových opakovačích teoreticky např. ve formě atomu cesia (přístup se zkouší na California Institute of Technology nebo Harvard University). Pokusy také probíhají ve volném prostoru, zatím se však dosahuje příliš malých vzdáleností, cca 20 kilometrů (Univerzita Ludwiga Maximillianse v Mnichově). Většina implementací kvantové kryptografie není uzpůsobena k přenosu dat, ale pouze k vytvoření naprosto tajného klíče. Proto se v praktickém využití systém použije na výměnu klíče pro danou relaci a nějaký jiný přenosový systém pro šifrování zpráv v relaci za využití klíče získaného kvantovou kryptografií. Hybridní šifrovací systémy ostatně nejsou ničím výjimečným ani v klasické kryptografii. V říjnu roku 2003 tři švýcarské společnosti oznámily vybudování infrastruktury klíče založené právě na kvantové kryptografii. Partnery v bezpečné šifrovací infrastruktuře jsou id Quantiqe výzkumná společnost v oblasti kvantové kryptografie, WISeKey, poskytovatel služeb pro certifikační autority PKI (Public Key Infrastructure), a OISTE, mezinárodní normalizační orgán pro oblast bezpečných elektronických transakcí. Prvními zákazníky budou pravděpodobně finanční instituce a vládní úřady.
41
V listopadu 2003 přišla začínající americká společnost MagiQ se svým systémem kvantové kryptografie. Jejich Navajo Secure Gateway (stejně příhodné jméno jako název celé firmy) stojí 50 tisíc dolarů, čímž má velmi konkurovat současné nabídce podobných systémů na trhu. Používá metodu BB84 na doposud nejdelší vzdálenost 120 kilometrů. Systém je určen pro virtuální privátní sítě (VPN) pro finanční instituce, armádu nebo vládu. [11],[12]
42
5 Novodobé trendy v kryptografii Vědci začali postupně hovořit o nové vědní disciplíně: o kvantové fyzice či o kvantové mechanice. Už Albert Einstein upozorňoval na „strašidelné působení částic na dálku“. Podle něj mohly být dva miniaturní kousky hmoty určitým způsobem propojeny na libovolně velkou vzdálenost. Cokoliv se přihodí jednomu, stane se i druhému. A právě tato provázanost částic je východiskem nedávného experimentu dánských vědců: Eugene Polzik z Institutu Nielse Bohra Kodaňské univerzity společně s kolegy teleportoval světelný paprsek na hmotný objekt - shluk atomů. Zatím na vzdálenost půl metru. Zdařilý pokus sice neodstartuje přemisťování lidí na jiné planety po vzoru seriálu Star Trek, patrně však bude znamenat přelom v ochraně údajů. To může v situaci, kdy se informace stávají nejcennějším zbožím na světě, zásadně ovlivnit ekonomiku, politiku i obranu řady států.
5.1
Teleportace
Pojem teleportace znamená, že chceme přenášet nějaký objekt nepřímo. Místo něj budeme přenášet jen informaci o něm a na straně příjemce podle ní vytvoříme objekt identický s původním. Klasická (nekvantová) teleportace předpokládá, že na vstupním objektu provedeme měření, klasickým kanálem odešleme získanou informaci a podle ní objekt rekonstruujeme. Potíž je v tom, že kvantová mechanika nedovoluje získat měřením plnou informaci o klasickém stavu objektu. Nicméně v roce 1993 odvodil Charles Bennett teleportační protokol, který umožňuje přenést kvantový stav, aniž bychom jej znali. Přenášená informace bude mít dvě části – kvantovou a klasickou. Kvantová část se "přenáší" okamžitě pomocí měření na jednom qubitu z propleteného páru stavů. Klasická informace může být předána třeba telefonem nebo jinou konvenční cestou, přičemž rychlost přenosu je shora omezena rychlostí světla.
43
Obrázek 11: scénář kvantové teleportace, http://www.aldebaran.cz/bulletin/2004_31_tel.html
Vstupem procesu je atom P v neznámém stavu, který chce Alice teleportovat Bobovi. Dále ještě před vlastní teleportací musíme připravit entanglovaný pár atomů A a B v Bellově stavu. Jednu složku páru (A) odneseme na stranu Alice, druhou složku (B) k Bobovi. Při teleportaci nejprve Alice provede s atomy A a P měření v Bellově bázi a jako výsledek měření zjistí jeden ze 4 možných Bellových stavů. Zároveň se při měření promítne stav Ψ do stavu atomu A. Díky kvantové propletenosti se tato změna okamžitě projeví i na atomu B, který má Bob. Ovšem aby Bob mohl rekonstruovat původní stav Ψ, potřebuje navíc znát výsledek měření Alice. Musí se s ní tedy domluvit nějakou klasickou cestou. Na základě této informace už může Bob na svém atomu B provést takovou unitární transformaci, která vede do stavu Ψ. V tu chvíli je atom B nerozlišitelný od původního P a teleportace se povedla. Podivuhodné je, že ani klasická, ani kvantová část přenášené informace sama o sobě neříká nic o stavu Ψ. Když Alice provede měření, dojde okamžitě ke kolapsu propleteného páru, ale dokud se Bob nedozví výsledek měření, nemůže si toho všimnout. Bude-li Bob v tu chvíli měřit, všechny Bellovy stavy páru pro něj mají stejnou pravděpodobnost. Kolaps je sice nelokální, ale nepřenáší žádnou informaci. A výsledky měření, které Alice získala, by samy o sobě také Bobovi nebyly k ničemu, neboť pro stejný stav Ψ jsou pokaždé jiné.
44
Dále poznamenejme, že při měření v Bellově bázi na straně Alice přejde atom P ze stavu Ψ do jiného. Proto není možné touto cestou "klonovat" atomy – původní objekt před teleportací zanikne. Protokol dřívějších pokusů s fotony se nezabýval analýzou Bellových stavů. Alice jen zjišťovala, zda se objeví právě ten Bellův stav, při němž Bob nemusí provádět žádné rotace pro rekonstrukci stavu Ψ. Ve zbylých 3 případech ze 4 byl teleportovaný stav ztracen. Letos realizované protokoly zahrnují podmíněné rotace a v ideálním případě tedy nabízí úspěšnost 100 %. [15]
5.2
Spolehlivá šifra zapsaná do miniaturních částic
Internet nebo jakákoliv jiná síť, se skládá z jednotlivých uzlů. V nich jsou uloženy informace (například data na pevném disku počítače). Po propojení kabely si počítače mohou vyměňovat informace a komunikovat mezi sebou. Podobný systém by však mohl pracovat i na kvantové úrovni: uzly, jakési paměťové bloky, by byly tvořené obláčky atomů. O jejich propojení by se postaral světelný paprsek. Vědci zatím teleportaci provedli na vzdálenost půl metru, a to hlavně s ohledem na rozměry optického stolu. Světelný paprsek můžeme vést třeba optickým vláknem. S jeho pomocí tak například švýcarští vědci v Ženevě přenesli fotony na vzdálenost čtyř kilometrů. Na internetu probíhá celá řada transakcí - běžně komunikujeme s bankami, nakupujeme ve virtuálních obchodech, svěřujeme internetu čísla kreditních karet. Informace, které putují sítí, musí být nějakých způsobem zakódované. Bezpečnost dnes využívaných šifer je velmi často založena na předpokladu, že na zvládnutí jistých matematických operací potřebuje počítač velké množství času. Řada vědeckých týmů se však snaží vytvořit kvantový počítač. Ten by dovedl provádět několik operací souběžně, a proto by našel výsledek řádově mnohem rychleji. Po sestrojení kvantového počítače by se současné šifry staly bezcennými, účinnou ochranu tajných informací by poskytovala jen kvantová kryptografie. Její téměř stoprocentní spolehlivost je dána fyzikálními zákony a ochrana působí dokonce na dvou frontách: případnému Útočníkovi systém kvantové kryptografie maximálně ztěžuje čtení zpráv posílaných mezi Alenou a Bobem. Dalším ochranným
45
prvkem je fakt, že odposlech komunikace mohou její přímí účastníci odhalit. Alice s Bobem si tak včas všimnou, že útočník naslouchá, a vysílání ukončí.[14]
5.3
Superrychlý počítač
Na nejjednodušší úrovni je kvantová kryptografie dotažena ke komerčním aplikacím. Zatím se však zcela nedaří potlačit vliv šumu a ztrát. Šifrování proto funguje na vzdálenost pouze řádově několik desítek kilometrů. Pokročilé komunikační sítě, které využívají vzájemné působení světla a atomů, jsou stále v zárodcích. Uvedení do praxe může trvat deset i více let. Odborníci se nyní snaží prodloužit vzdálenost, na kterou je možné bezpečně komunikovat. Poměrně futuristický návrh Antona Zeilingera z Vídeňské univerzity například počítá s komunikací pomocí satelitů. Výměna informací mezi dvěma partnery na Zemi, mezi Alenou a Bobem, by tak probíhala prostřednictvím družic nesoucích světelný zdroj. Ještě delší bude cesta ke kvantovým počítačům. Dosud se podařilo sestrojit zařízení s méně než deseti kvantovými bity. Dnešní počítače naproti tomu pracují s gigabity nebo terabity informací. Zkonstruování kvantového počítače by však otevřelo netušené možnosti: někteří fyzikové na něj nahlížejí jako na jediné zařízení, které může určitý výpočet provádět zároveň s velkým množstvím čísel. Jiní ho chápou jako velké množství entit, jež se nacházejí v odlišných vesmírech a provádějí jediný výpočet.[13]
46
Závěr Cílem této práce bylo popsat a zhodnotit nejpoužívanější šifrovací metody současnosti. Práce celkem jednoznačně ukazuje, že pro současnou kryptografii plně dostačují jak dnešní typy symetrických metod, tak metoda veřejných a soukromých klíčů. Ovšem každá metoda má svoje specifika a nároky na implementaci. Vzhledem k výkonnosti
dnešních
výpočetních
systémů
jsou
současné
šifry
téměř
neprolomitelné. Řekněme, že jsou výpočetně bezpečné. Tato situace se však může dramaticky změnit s nástupem kvantových počítačů. Nicméně už v dnešní době se experimentálně zkoušejí nové metody, které se přizpůsobují provozu kvantových počítačů. Je nutné si však uvědomit, že ani sebelepší a sebedokonalejší šifrovací algoritmus není sám o sobě nic jiného než nástroj pro zajištění utajení. Celková bezpečnost však záleží na celé škále činností, které je potřeba dodržovat abychom mohly hovořit o bezpečném systému.
47
Seznam použité literatury [1]
PIPER, Fred; MURPHY, Sean. Kryptografie. 1.vyd. Praha: Dokořán s.r.o., 2006. ISBN 80-7363-074-5
[2]
KAHN, David, The Codebreakers, Scribner, 1996
[3]
SHANNON,Claude; A Mathematical Theory of Communication, The Bell System Technical Journal, Vol. 27, July, October, 1948 http://cm.bell-labs.com/cm/ms/what/shannonday/shannon1948.pdf
[4]
SHANNON,Claude; Communication Theory of Secrecy Systems, The Bell System Technical Journal, Vol. 28, 1949 http://www.cs.ucla.edu/~jkong/research/security/shannon1949.pdf
[5]
WHITFIELD, Diffie; HELLMAN,Martin , New directions in Cryptography, IEEE Transactions on Information Theory, No. 6, 1976
[6]
RIVEST,Ronald;SHAMIR, Adi; ADLEMAN,Leonard, A Method for Obtaining Digital Signatures and Public-Key Cryptosystems, Communications of the ACM, No. 2 Feb. 1978
[7]
DES, Data Encryption Standard FIPS PUB 46-3, October 1999 http://csrc.nist.gov/CryptoToolkit/tkencryption.html
[8]
International Association for Cryptologic Research, nezisková vědecká organizace, http://www.iacr.org/
[9]
Systém Echelon, http://www.heise.de/tp/english/inhalt/te/6929/1.html
[10] SINGH, Simon, Kniha kódů a šifer, český překlad, Argo a Dokořán, 2003, http://www.simonsingh.net/Crypto_Corner.html [11] BENNETT, Charles; BRASSARD, Gilles; EKERT, Arthur, Quantum Cryptography [12] Stránka Vlastimila Klímy, http://cryptography.hyperlink.cz/ [13] internetový portal http://www.google.com [14] internetový portál http://www.lupa.cz/ [15] http://www.aldebaran.cz/bulletin/2004_31_tel.html [16] RARITY,G.; TAPSTER,P.; GORMAN, M.; KNIGHT,P., Ground to satellite secure key exchange using quantum cryptography, New Journal of Physics 4 2002
48