Взлом Ceasar cipher — различия между версиями
Материал из InformationSecurity WIKI
ComAT0Zz (обсуждение | вклад) (Новая страница: «Шифр Цезаря — это вид шифра подстановки, в котором каждый символ в открытом тексте замен…») |
ComAT0Zz (обсуждение | вклад) |
||
Строка 1: | Строка 1: | ||
Шифр Цезаря — это вид шифра подстановки, в котором каждый символ в открытом тексте заменяется символом, находящимся на некотором постоянном числе позиций левее или правее него в алфавите. | Шифр Цезаря — это вид шифра подстановки, в котором каждый символ в открытом тексте заменяется символом, находящимся на некотором постоянном числе позиций левее или правее него в алфавите. | ||
− | Взлом данного шифра происходит методом перебора | + | Взлом данного шифра происходит методом перебора всех возможных сдвигов. Для этого можно использовать инструмент [https://www.nayuki.io/page/automatic-caesar-cipher-breaker-javascript Automatic Caesar cipher breaker] либо код на python, в котором строка '''Wkh_Txlfn_Eurzq_Ira_Mxpsv_Ryhu_Wkh_Odcb_Grj''' является зашифрованной: |
+ | |||
+ | a = 'Wkh_Txlfn_Eurzq_Ira_Mxpsv_Ryhu_Wkh_Odcb_Grj' | ||
+ | import string | ||
+ | def rotn(n): | ||
+ | from string import ascii_lowercase as lc, ascii_uppercase as uc | ||
+ | mapping = string.maketrans(lc + uc, lc[n:] + lc[:n] + uc[n:] + uc[:n]) | ||
+ | return mapping | ||
+ | for n in xrange(26): | ||
+ | a.translate(rotn(n)) |
Версия 13:01, 8 февраля 2016
Шифр Цезаря — это вид шифра подстановки, в котором каждый символ в открытом тексте заменяется символом, находящимся на некотором постоянном числе позиций левее или правее него в алфавите.
Взлом данного шифра происходит методом перебора всех возможных сдвигов. Для этого можно использовать инструмент Automatic Caesar cipher breaker либо код на python, в котором строка Wkh_Txlfn_Eurzq_Ira_Mxpsv_Ryhu_Wkh_Odcb_Grj является зашифрованной:
a = 'Wkh_Txlfn_Eurzq_Ira_Mxpsv_Ryhu_Wkh_Odcb_Grj' import string def rotn(n): from string import ascii_lowercase as lc, ascii_uppercase as uc mapping = string.maketrans(lc + uc, lc[n:] + lc[:n] + uc[n:] + uc[:n]) return mapping for n in xrange(26): a.translate(rotn(n))