WikiDer > Keystream

Keystream

В криптография, а ключевой поток это ручей из случайный или псевдослучайный символы, которые сочетаются с простой текст message для создания зашифрованного сообщения (зашифрованного текста).

«Персонажи» в ключевом потоке могут быть биты, байты, цифры или реальные символы, например A – Z, в зависимости от случая использования.

Обычно каждый символ в ключевом потоке либо добавляется, либо вычитается, либо XORed с символом в открытом тексте для создания зашифрованного текста, используя модульная арифметика.

Ключевые потоки используются в одноразовый блокнот шифр и в большинстве потоковые шифры. Блочные шифры также может использоваться для создания ключевых потоков. Например, режим CTR - это блочный режим это заставляет блочный шифр создавать поток ключей и, таким образом, превращает блочный шифр в потоковый шифр.

пример

В этом простом примере мы используем английский алфавит из 26 символов от a до z. Таким образом мы не можем зашифровать числа, запятые, пробелы и другие символы. Тогда случайные числа в ключевом потоке должны быть как минимум от 0 до 25.

Чтобы зашифровать, мы добавляем номера ключевого потока в открытый текст. И для расшифровки мы вычитаем те же номера ключевого потока из зашифрованного текста, чтобы получить открытый текст.

Если число зашифрованного текста становится больше 25, мы преобразуем его в значение от 0 до 25. Таким образом, 26 становится 0, 27 становится 1 и так далее. (Такая упаковка называется модульная арифметика.)

Здесь текстовое сообщение «атака на рассвете» комбинируется путем добавления с ключевым потоком «kjcngmlhylyu» и дает зашифрованный текст «kcvniwlabluh».

Простой текстаттаckатdашп
Открытый текст в виде чисел019190210019302213
Keystreamkjcпгмлчасyлyты
Keystream как числа10921361211724112420
Шифрованный текст в виде чисел10282113822112627114633
Шифрованный текст в виде чисел
завернутые до 0-25
1022113822110111207
Зашифрованный текст как текстkcvпяшлаблтычас

использованная литература