WikiDer > Шифр XOR

XOR cipher

В криптография, то простой шифр XOR это тип аддитивный шифр,[1] ан алгоритм шифрования который действует по принципам:

А 0 = А,
А А = 0,
Б) С = А (B C),
(B А) А = В 0 = B,

куда обозначает исключительная дизъюнкция (XOR) операция. Эта операция иногда называется сложением по модулю 2 (или идентичным вычитанием).[2] С помощью этой логики можно зашифровать строку текста, применив побитовый оператор XOR к каждому символу с использованием заданного ключа. Чтобы расшифровать вывод, просто повторно применив функцию XOR с ключом, шифр будет удален.

Пример

Например, строка «Вики» (01010111 01101001 01101011 01101001 в 8-битном ASCII) можно зашифровать с помощью повторяющегося ключа 11110011 следующее:

01010111 01101001 01101011 01101001
11110011 11110011 11110011 11110011
=10100100 10011010 10011000 10011010

И наоборот, для расшифровки:

10100100 10011010 10011000 10011010
11110011 11110011 11110011 11110011
=01010111 01101001 01101011 01101001

Использование и безопасность

Оператор XOR чрезвычайно распространен как компонент более сложных шифров. Сам по себе, используя постоянный повторяющийся ключ, простой шифр XOR можно тривиально взломать, используя частотный анализ. Если содержание любого сообщения можно угадать или узнать иным образом, то ключ может быть раскрыт. Его основное достоинство состоит в том, что его просто реализовать, а операция XOR является недорогой в вычислительном отношении. Поэтому простой повторяющийся шифр XOR (то есть использование одного и того же ключа для операции xor над всеми данными) иногда используется для сокрытия информации в случаях, когда не требуется особой защиты. Шифр XOR часто используется в компьютерных вредоносных программах, чтобы затруднить обратное проектирование.

Если ключ является случайным и по крайней мере равен длине сообщения, шифр XOR намного более безопасен, чем когда в сообщении есть повторение ключа.[3] Когда ключевой поток генерируется генератор псевдослучайных чисел, в результате потоковый шифр. С ключом, который действительно случайный, в результате одноразовый блокнот, что теоретически неразрывно.

В любом из этих шифров оператор XOR уязвим для атака с известным открытым текстом, поскольку простой текст зашифрованный текст = ключТакже тривиально перевернуть произвольные биты в дешифрованном открытом тексте, манипулируя зашифрованным текстом. пластичность.

Пример реализации

Пример использования Python язык программирования.[4]

из __будущее__ импорт print_function, unicode_literalsиз Операционные системы импорт случайныйdef Genkey(длина: int) -> байты:    "" "Сгенерировать ключ." ""    возвращаться случайный(длина)    def xor_strings(s, т) -> байты:    "" "xили две строки вместе." ""    если это экземпляр(s, ул.):        # Текстовые строки содержат одиночные символы        возвращаться б"".присоединиться(chr(ord(а) ^ ord(б)) за а, б в застегивать(s, т))    еще:        # Объекты Python 3 байта содержат целочисленные значения в диапазоне 0-255        возвращаться байты([а ^ б за а, б в застегивать(s, т)])        сообщение = "Это секретное сообщение"Распечатать('Сообщение:', сообщение)ключ = Genkey(len(сообщение))Распечатать('Ключ:', ключ)cipherText = xor_strings(сообщение.кодировать('utf8'), ключ)Распечатать('cipherText:', cipherText)Распечатать('расшифровано:', xor_strings(cipherText, ключ).расшифровать('utf8'))# Проверятьесли xor_strings(cipherText, ключ).расшифровать('utf8') == сообщение:    Распечатать("Модульный тест пройден")еще:    Распечатать("Сбой модульного теста")

Смотрите также

Рекомендации

  1. ^ Тутте 1998, п. 3
  2. ^ Дом церкви 2002, п. 11
  3. ^ Дом церкви 2002, п. 68
  4. ^ Это было вдохновлено Рихтер, Вольфганг (3 августа 2012 г.), «Нерушимая криптография за 5 минут», Crossroads: журнал ACM для студентов, Ассоциация вычислительной техники

Библиография