Útok zvoleným klíčem je jednou z metod kryptoanalytického útoku , která sleduje činnost šifrovacího algoritmu využívajícího několik tajných klíčů . Kryptanalytik má zpočátku pouze informace o určitém matematickém vztahu, který spojuje klíče dohromady.
Podle Kerckhoffsova principu má kryptoanalytik všechny potřebné informace o použitém šifrovacím systému, kromě určité sady tajných parametrů nazývaných klíč. Kryptanalytik zná pouze vztah mezi párem klíčů. K uhodnutí obou klíčů používá šifrový text a daný poměr. Jsou známy dva typy útoků na vybraný klíč: útok pomocí zvoleného klíče a známého otevřeného textu, při kterém kryptoanalytik specifikuje pouze vztah mezi párem klíčů, a útok pomocí zvoleného klíče a otevřeného textu, při kterém kryptoanalytik nastaví vztah mezi klíčový pár a a samotný prostý text, který má být zašifrován. [jeden]
Útok na základě zvoleného klíče se provádí stejným způsobem na všechny kryptosystémy, včetně tzv. „černé skříňky“, ve které jsou neznámé všechny vlastnosti. Tato "černá skříňka" využívá funkci šifrování , která se volí stejným způsobem pro náhodné permutace zpráv. Bity klíče jsou vybírány náhodně, takže znalost šifrového textu nám nemůže říci nic o šifrovém textu klíče .
Algoritmus útoku založený na zvoleném klíči na „černé skříňce“ může kromě standardních operací kdykoli během výpočtu vyžadovat:
Algoritmus může mít také přístup k generátoru náhodných bitů. Na konci výpočtu je výstupem odhadovaný klíč . [2]
Pokud tedy uživatel používá tajný klíč a veřejný kryptosystém ( kryptosystém veřejného klíče ), může si kryptoanalytik kdykoli vybrat zprávu a inverzní vektor a provést šifrování nebo dešifrování . Hlavní aplikací útoku na uhádnutý klíč je ověřování systémů, ale za určitých okolností lze tento útok aplikovat v praxi. Pokud se k přenosu klíče relace od uživatele k uživateli použije proudová šifra a kryptoanalytik získá kontrolu nad přenosovou linkou, může změnit libovolné bity klíče podle svých představ a obdrží změněný klíč místo . Poté, když zahájí přenos pomocí nesprávného klíče, obdrží zkomolenou zprávu a zahájí proceduru obnovy. Mezitím kryptoanalytik obdrží text zašifrovaný klíčem. (Dobrá krypto ochrana může takové útoky odvrátit použitím nových nezávislých klíčů relace nebo přidáním nelineárních bitů detekce chyb do klíče relace, kdykoli je potřeba procedura obnovy. Historie však ukazuje, že dobrá krypto ochrana to vždy nedodržuje. je žádoucí mít systém, který při takovém útoku nepadá) [3] .
V této části se budeme zabývat útokem, který nezávisí na konkrétní slabosti ve funkci šifrování. Jedná se o útok typu man-in-the-middle ( MITM ). Tento typ útoku umožňuje zkrátit dobu pokročilého vyhledávání v závislosti na počtu povolených inverzí klíče [4] .
Teorém. Nechť je bloková šifra s n-bitovým klíčem. Předpokládejme, že kryptoanalytik může provádět inverze a má slova paměti. Poté bude schopen rozluštit šifru v dalších krocích [4] .
Důkaz:
Analytik všemi možnými způsoby nahrazuje poslední bity v klíči . Například šifruje hodnoty
,kde je soukromý klíč uživatele a jakákoli vhodná zpráva. Z hodnot [4] vytvoří hashovací tabulku .
Poté provede šifrování změnou prvních bitů klíče a resetováním posledních bitů:
.Po všech výpočtech je každá hodnota porovnána s hashovací tabulkou [4] .
Pokud je původní klíč prolomen přes , kde se skládá z posledních bitů, bude záznam odpovídat výsledku pomocí šifrování ve druhé fázi. Když je nalezena shoda, bude to kandidátský klíč. Několik falešných poplachů je možné, pokud se zprávou shoduje více klíčů , ale stejně jako v případě útoku s odpovídajícím textem je jeden nebo dva další bloky známého otevřeného textu téměř jistě vyloučí, s malým dopadem na dobu běhu [4] .
Závěr: Pomocí neomezeného počtu útoků se zvoleným klíčem lze prolomit jakoukoli blokovou šifru s n-bitovým klíčem pouze pomocí výpočtů v paměti [4] .
Důkaz: Pojďme si vybrat .
Poznámka: Pro velké množství příkladů a velké množství dostupné paměti bude mnohem efektivnější obě fáze v důkazu věty prohodit. Vypočítat a uložit šifrování do paměti. U každého úkolu proveďte inverze a zkontrolujte, zda tabulka vyhovuje. Iterace tedy budou vynaloženy na každý další úkol [4] .
Schopnosti tohoto typu útoku si ukážeme na kryptosystému, který se ukázal jako extrémně odolný proti útokům se shodným textem [3] .
Nechť je tajná bloková šifra s klíčem o velikosti bitů. Pojďme definovat novou blokovou šifru .
pokud je první bit 0 v ostatních případech, kdy výsledkem inverze prvního bitu je například . legitimní bloková šifra: pokud je první bit klíče 0 , v ostatních případechPokud má hlavní šifra dobrou n-bitovou ochranu, pak prolomení šifry útokem na analýzu textu vyžaduje pokročilé vyhledávání v klíčovém bitovém prostoru. Jinými slovy, pokud analytik nemá informace o šifře , může potřebné informace získat, pokud šifruje nebo dešifruje pomocí klíčů nebo [3] .
I když je šifra obtížně prolomitelná vybraným textovým útokem, je velmi snadné ji prolomit útokem zvoleného klíče. Analytik potřebuje dvě šifry: a pro nějakou vhodnou zprávu . Pokud je první bit nula, pak
V ostatních případech
[3] .Analytik tedy okamžitě obdrží všechny bity klíče , kromě prvního, a může dokončit operaci, protože zná otevřený text [4] .
V šifře LOKI89 má každá volba ze dvou podklíčů , jeden ze sudého cyklu a jeden z lichého cyklu, odpovídající 64bitový klíč. Protože všechny algoritmy pro získání dvou podklíčů z předchozích dvou jsou stejné, umístění cyklů, ve kterých jsou umístěny dva aktuální podklíče, neovlivní výstup následujících podklíčů. Pokud opravíme dva podklíče a klíče a definujeme druhý klíč výběrem a , budou hodnoty podklíčů klíče stejné jako následující podklíče klíče . V tom případě, . Tento vztah je zachován pro libovolné dva klíče zvolené tímto způsobem: pokud jsou informace před druhým šifrovacím cyklem s klíčem stejné jako informace před prvním šifrováním pomocí klíče , pak jsou informace a vstupní data funkce stejné . v obou operacích posunuto o jeden cyklus. V tomto případě, pokud je otevřený text zašifrován klíčem , bude šifrovaný text před druhým cyklem . Přijatá data jsou stejná jako ta nalezená před prvním šifrovacím cyklem s klíčem , jehož hodnota bude , a tedy v tomto páru
P ∗ = ( P R , P L ⊕ K L ⊕ R Ó L 12 ( K L ) ⊕ F ( P R ⊕ K R , K L ) ) {\displaystyle P^{*}=(P_{R},P_{L}\oplus K_{L}\oplus ROL12(K_{L})\oplus F(P_{R}\oplus K_{R},K_ {L}))} Můžete vidět, že pravá strana výrazu je stejná jako levá strana výrazu a poměr ostatních dvou částí závisí na klíči. V takovém páru existuje podobný vztah mezi šifrovými texty: C ∗ = ( C R ⊕ K L ⊕ R Ó L 12 ( K L ) ⊕ F ( C L ⊕ K R , K L ) , C L ) . {\displaystyle C^{*}=(C_{R}\oplus K_{L}\oplus ROL12(K_{L})\oplus F(C_{L}\oplus K_{R},K_{L}), C_{L}).} Grafy popisují vztah mezi podklíči dvou klíčů a vztah mezi hodnotami během procesu šifrování.SYSTÉM
Útok s holým textem se shodným klíčem, který spoléhá na tyto vlastnosti, vybere 32bitovou hodnotu , otevřené texty , jejichž pravé strany jsou , a jejichž 32bitové levé poloviny jsou náhodně vybrány, a prosté texty , jejichž levé strany jsou , a jejichž pravé strany jsou vybrány náhodně. Dva neznámé přidružené klíče se používají k šifrování dat v otevřeném textu ve zkoumaném systému: klíč se používá k šifrování prvních otevřených textů a klíč se používá k šifrování zbývajících otevřených textů. Pro každý pár otevřených textů je zaručeno, že as vysokou pravděpodobností existují dva otevřené texty takové, že . U takové dvojice zůstávají data stejná, pokud se obě provedení posunou o jeden cyklus. Takovou dvojici lze snadno vybrat, pokud existuje, kontrolou rovnosti Pravděpodobnost, že tento test náhodně projde, je tedy schopno projít jím jen několik párů.
Páry, které mají tyto vlastnosti prostého a šifrového textu, splňují klíčové požadavky (1) a (2). Pro tuto dvojici je tedy splněn vztah , ve kterém je hodnota jedinou neznámou . Ze všech možných hodnot tuto rovnici splňuje pouze několik. Pomocí diferenciální kryptoanalýzy a optimalizačních technik lze najít hodnotu pomocí několika operací. Jakmile je hodnota nalezena , je snadné vypočítat pomocí vzorců (1) a (2) a získat a .
Podobný útok typu selected-key-known-plaintext používá známé otevřené texty zašifrované neznámým klíčem a otevřené texty zašifrované souvisejícím klíčem . Dvojici s těmito vlastnostmi lze snadno identifikovat podle 32 běžných bitů prostého textu a 32 společných bitů šifrového textu. Tento pár lze použít k hledání klíčů stejným způsobem jako při zvoleném klíči a zvoleném útoku v otevřeném textu. [jeden]
Podle Bruce Schneiera existuje 7 hlavních způsobů kryptanalytického útoku [5] :
V případě útoku založeného na šifrovaném textu má kryptoanalytik přístup pouze k šifrovanému textu. Jedná se o nejobtížnější typ útoku kvůli malému množství dostupných informací.
Při útoku se známým holým textem zná kryptoanalytik holý i šifrovaný text. Tento typ útoku je účinnější než útok založený na šifrovaném textu díky většímu množství známých informací o kryptosystému.
Zvolený útok v otevřeném textu je silnějším typem útoku než známý útok v otevřeném textu. Možnost předvýběru otevřeného textu poskytuje více možností pro extrakci systémového klíče. Je také pravda, že pokud je kryptosystém zranitelný vůči známému útoku v prostém textu, pak je také zranitelný vůči vybranému útoku v prostém textu. [jeden]
Útok na odpovídající klíč je silnější než útok na odpovídající text. Okamžitě prolomí speciálně vytvořenou blokovou šifru, která je zabezpečená proti dalším útokům. U jakékoli blokové šifry může zvolený útok klíčem urychlit proces pokročilého vyhledávání v závislosti na počtu povolených inverzí klíče. Pro neomezený útok na uhodnutý klíč lze množství práce snížit jako druhou odmocninu. Tyto výsledky jsou nejlepší možné pro obecný útok, který se nespoléhá na žádnou konkrétní blokovou šifru.