AT T Мейджором Джозефом Моборном и Гильбертом Вернамом. В 1. 94. 9 годах была опубликована работа Клода Шеннона, где Шеннон доказал абсолютную стойкость шифра Вернама. В этой работе, Шеннон показал что не существует других шифров с подобными свойствами и его выводом стало следующее утверждение шифр Вернама самая безопасная криптосистема из всех имеющихся. Однако, следует заметить, что для того чтобы шифр действительно был стойким необходимо выполнение следующих трех правил Ключ для шифрования выбирается случайным образом. Длина ключа должна быть равна длине открытого текста. Ключ должен использоваться ТОЛЬКО один раз. А теперь поподробней о самом шифре и процессе шифрования. Так как этот шифр был придуман для компьютерных систем, то следует заметить что базируется он на двоичной арифметике. Надеюсь что вы знакомы с ней. Таким образом, так как у нас двоичная арифметика, то все операции будут осуществляется над нулем 0 и единицей 1. Логическая операция XOR в отличие от операции OR при логическом сравнении 0 и 1 дает 1, при сравнении 1 с 1 дает 0, а при 0 с 0 дает 0. Следовательно, если мы выполним операцию XOR над числами 1. Надеюсь что принцип работы операции XOR понятен. То шифр Цезаря можно представить в виде функции. Вернам предложил использовать для шифрования преобразование. Программа разложит число MДалее, так как шифр работает с двоичной системой исчисления, необходимо понимать что буквы это всего лишь некоторая интерпретация числа, то есть число является кодом символа некоторой таблицы кодировок. К примеру, наиболее популярные таблицы кодировок это ANSI, ASCII и UTFunicode. Естественно, что в каждой таблицы один и тот же символ может иметь разный код, поэтому во избежании путаницы имейте это ввиду и используйте одну и ту же кодировку при шифровании и дешифровании. Кроме того, данный шифр может использоваться не только на компьютерах. Его можно применить и к тексту написанному на бумаге. Только перед применением надо сделать некие преобразования. Таким образом, перед тем как осуществить шифрование необходимо перевести все символы в их однозначную числовую интерпретацию. Если Вы решили применить шифр в компьютерных системах то для вас уже существуют соответствующие кодировки, и язык программирования выбранный Вами скорее всего поддерживает явное или неявное преобразование. И вам остается только произвести над каждой парой операцию XOR. Шифрование Методом Вернама Программа' title='Шифрование Методом Вернама Программа' />В различных языках это операция определяется по разному, приведу пример для PasсalDelphiAssembler xor, CC. Символика Животных В Славянской Народной Традиции. Например, если вы используете русский алфавит без учета буквы то это будет выглядеть так а 0. Тем самым мы определили свою таблицу кодировки. После этого, написав сообщение и придумав ключ, преобразуйте, каждый символ в их числовое значение, соответствующее вашей таблице кодировки, и после этого осуществляйте операцию XOR над каждой соответствующей парой. Так как данный метод шифрования является симметричным, следовательно применив операция XOR каждой паре символов шифр текста шифрограммы и ключа, мы получим открытый текст. На основе изученного материала, я покажу как реализовать шифр Вернама на СС и PascalDelphi. Программу целиком писать нет надобность, поэтому будем рассматривать блочную структуру, для того чтобы каждый мог без особого труда заточить ее под сви надобности. В криптографии шифр Вернама известен также как схема одноразовых. Программу целиком писать нет надобность, поэтому будем. Нужно написать программу для шифрования файлов шифром Вернама. В качестве ключа программа должна хавать строку,сама. Шифр Вернама симметричный шифр с абсолютной криптографической. Скачать эту программу для шифрования шифра Вернама можно здесь. Под катом Шифр Цезаря Шифр пар Шифр четырех квадратов Матричный шифр Шифр ADFGX Шифр Виженера Шифр Цезаря Каждую. Шифрование Методом Вернама Программа' title='Шифрование Методом Вернама Программа' />А теперь, от слов к делу. Допусти что у нас есть строка или массив символов o. Str. Это будет открытый текст, который надо зашифровать. Теперь нам надо определить случайный ключ, длиной равной длине открытого текста. Для простоты понимания, мы воспользуемся стандартной функцией генерации случайных чисел random для PascalDelphi и rand для CC. Но замечу сразу что это не лучший вариант, в случае если вы хотите реализовать действительно стойкий шифр. Данный пример выбран из соображения простоты. Теперь покажем как это будет выглядеть в исходном коде PascalDelphivaro. Str, key string i integer begino. Str Holo word определяем открытый текстrandomize Необходимая функция для функции random, чтобы последняя каждый раз выдавала случайные значениягенерируем случайный ключ длиной равной длине открытого текстаfor i 1 to lengtho. Str dokey. Теперь нам осталось лишь реализовать шифрование, для этого мы опишем цикл в котором мы будем посимвольно осуществлять операцию XOR. Но для этого нам понадобиться еще объявить массив приемник, в который мы поместим зашифрованный текст. Смотрим PascalDelphiprocedure shifr. Надеюсь, что вы догадаетесь как реализовать дешифровкуПодсказка те же действия нужно провести для шифрованного текста. Спасибо за внимание.