Криптографические системы
| Категория реферата: Рефераты по информатике, программированию
| Теги реферата: банк бесплатных рефератов, bestreferat
| Добавил(а) на сайт: Георгий.
Предыдущая страница реферата | 1 2 3 4 5
Основные функции работы с ключами:
генерирование пары секретный/открытый ключи;
ведение каталогов открытых и секретных ключей;
подпись и удостоверение открытого ключа;
защита секретного ключа фразой пароля.
Кроме того, PGP выполняет множество дополнительных функций, которые расширяют ее возможности и повышают удобство работы с программой.
Основной особенностью системы является реализация криптографического алгоритма с открытым ключом RSA. Применение RSA обеспечивает секретность передачи данных через сети коммуникации, так как данные шифруются открытым ключом, а расшифровываются секретным. Открытые ключи могут свободно распространяться по любым каналам, потому что с их помощью невозможно декодировать сообщение. Таким образом, PGP эффективно решает важную проблему распределения криптографических ключей.
Алгоритм шифрования с открытым ключом значительно медленнее, чем стандартное шифрование с одним ключом. Поэтому PGP шифрует сообщения с помощью высококачественного быстрого стандартного алгоритма шифрования с одним ключом, используя временный произвольный ключ. Открытый ключ получателя используется только для шифровки этого временного стандартного ключа, который посылается вместе с зашифрованным текстом получателю. Получатель использует свой собственный секретный ключ, чтобы восстановить временный ключ, и затем применяет его для выполнения быстрого стандартного алгоритма декодирования с одним ключом, чтобы декодировать все зашифрованное сообщение. Данный подход позволяет совместить преимущества алгоритмов с открытым ключом с высокой надежностью и быстродействием стандартных алгоритмов.
Исходный текст программы PGP написан на языке C и включает в себя следующие модули:
pgp.c - головной модуль;
basslib.c - функции стандартного шифрования;
basslib2.c - санкционирование доступа по паролю;
keygen.c - подпрограммы генерации ключей алгоритма RSA;
random.c - подпрограммы генерирования случайных чисел;
rsalib.c - математические функции алгоритма RSA;
rsaio.c - функции ввода/вывода;
lfsr.c - подпрограмма реализации линейного сдвигового регистра (LFSR);
memmgr.c - функции распределения памяти;
md4.c - функции подписи сообщений;
Головной модуль pgp.c обеспечивает интерфейс системы с пользователем и взаимодействие ее компонентов. Входящая в него функция main() производит разбор командной строки, через которую пользователь указывает команду. В соответствии с командой main() производит последовательный вызов необходимых подпрограмм, обеспечивая их согласованную работу.
Модуль basslib.c реализует алгоритм BassOmatic. Это стандартный блоковый шифратор размером блока 256 байт. Он использут ключи размером 512, 1024 и 2048 бит (в зависимости от необходимого уровня криптостойкости). Он может использовать шифрование в режиме обратной связи.
Модуль keygen.c генерирует пару открытый/секретный ключи алгоритма RSA. Это непростая задача, требующая реализации многих численных алгоритмов. В kegen.c реализованы алгоритмы проверки простых чисел, быстрого просеивания простых чисел, проверки взаимной простоты двух чисел, алгоритм Евклида. Все эти алгоритмы оперируют со 100-битными числами.
Модуль random.c реализует подпрограмму генерирования случайных чисел, используемых для создания ключей алгоритмов RSA и BassOmatic. Случайные значения вычисляются как промежутки времени между нажатием пользователем на клавиатуру. Каждый полученный байт помещается в специальный буфер и становится доступным для функций модулей keygen и basslib.
В memmgr.c находятся функции управления памятью: выделение, освобождение, очистка.
Модуль rsalib.c реализует математические функции (в частности, возведение в степень) над операндами произвольной длины. Эти функции необходимы для шифрования/дешифрования данных алгоритмом RSA.
Взаимодействие модулей при выполнении типичных команд проиллюстрировано на схемах 4.1-4.3.
Схема 4.1. Генерирование пары открытый/секретный ключи для алгоритма RSA.
Схема 4.2. Шифрование файла стандартным криптографическим алгоритмом.
Схема 4.3. Шифрование файла открытым ключем получателя.
Скачали данный реферат: Тихоненко, Кутиков, Федосья, Габулов, Кутлыев, Ханилов, Кима.
Последние просмотренные рефераты на тему: бесплатные тесты бесплатно, сочинение 7, контрольная работа 1, онегин сочинение.
Категории:
Предыдущая страница реферата | 1 2 3 4 5