Криптографические системыРефераты >> Программирование и компьютеры >> Криптографические системы
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. Шифрование файла открытым ключем получателя.