Научная статья на тему 'Обучающая компьютерная программа для изучения российского стандарта криптографического преобразования'

Обучающая компьютерная программа для изучения российского стандарта криптографического преобразования Текст научной статьи по специальности «Компьютерные и информационные науки»

CC BY
68
15
i Надоели баннеры? Вы всегда можете отключить рекламу.
i Надоели баннеры? Вы всегда можете отключить рекламу.

Похожие темы научных работ по компьютерным и информационным наукам , автор научной работы — Воронков Борис Николаевич, Проскурин Илья Николаевич

iНе можете найти то, что вам нужно? Попробуйте сервис подбора литературы.
i Надоели баннеры? Вы всегда можете отключить рекламу.

Текст научной работы на тему «Обучающая компьютерная программа для изучения российского стандарта криптографического преобразования»

Обучающая компьютерная программа для изучения российского стандарта криптографического преобразования

Б. Н. Воронков, Воронежский государственный университет, [email protected], И. И. Проскурин, Воронежский государственный университет,

pro@autosputnik. ги)

В настоящее время в вузах Российской Федерации базовые стандарты обучения для ряда специальностей включают в себя вопросы, связанные с изучением методов и средств защиты информации. Для успешного освоения данных вопросов необходимо понимание принципов и знание основных элементов криптографического преобразования информации.

Известно несколько компьютерных обучающих программ, позволяющих быстро и достаточно полно ознакомиться с алгоритмами шифрования и расшифрования данных, используемыми в традиционных симметричных и современных асимметричных криптосистемах [1 - 3]. К сожалению, эти программы, представленные в сети Интернет, не сопровождаются исходными текстами, ограничиваются краткой справочной информацией и содержат большое число ошибок и недочетов. К тому же в них приводятся только зарубежные стандарты. В [4] рассматривается упрощенный вариант обучающей программы по изучению российского стандарта шифрования, реализующий лишь один из режимов шифрования. Ниже описывается модифицированная и более полная версия.

1. Принципы работы алгоритма ГОСТ 28147-89 [5]

• криптосистема симметричная (одноключевая);

• блочная, с длиной блока 64 бит, однако в режимах гаммирования и гамми-рования с обратной связью реализуется поточное шифрование;

• длина ключа 256 бит, для генерации псевдослучайной последовательности, используемой при поточном шифровании, требуется синхропосылка длиной 64 бит;

• используется лишь один метод шифрования - метод замены, структура алгоритма базируется на использовании схемы Фейстеля [6], применяется сложение по модулю 2, 232 и (232-1);

• предусматривает три основных режима шифрования данных : простая замена, гаммирование, гаммирование с обратной связью и один дополнительный режим выработки имитовставки;

• количество раундов шифрования - 32, а в режиме выработки имитовстав-

ки - 16;

• нелинейность преобразования информации в функции шифрования обеспечивается применением динамических таблиц замены;

• циклы шифрования и расшифрования являются взаимнообратимыми за

счет обратного порядка использования ключевых элементов.

Сформулированные принципы позволяют выявить различия между

американским стандартом шифрования DES (Data Encryption Standard), рядом других симметричных алгоритмов и российским ГОСТ 28147 -89.

2. Описание программы

Компьютерная программа предназначена для изучения пользователем алгоритма криптографического преобразования ГОСТ 28147-89 в форме пошагового обучения с одновременным пояснением этапов и наглядной демонстрацией шагов обучения на соответствующих блок-схемах. Кроме того, для реального шифрования информации, хранящейся в файлах, реализованы все три основных режима криптопреобра-зований, а также возможность шифрования информации, вводимой с клавиатуры.

Важным обучающим моментом является то, что большее внимание уделяется изучению самого алгоритма, а не выполнению трудоемких однообразных тестов, как в [1]. Правильное и быстрое выполнение основных этапов обучения обеспечивает функция «демонстрация».

Для успешного освоения алгоритма необходимо уметь переводить числа из двоичной и шестнадцатиричной систем счисления в десятичную и обратно, а также выполнять операции сложения по модулям 2, 232, (232 - 1).

2.1. Общие сведения

Название программного продукта «ГОСТ 28147: обучение». Программа реализована в среде программирования Borland Delphi 7. Программный продукт состоит из одного запускаемого модуля ГОСТ89.ехе. Программа функционирует в операционных системах Windows 2000, Windows XP, Windows Vista Business.

2.2. Функциональное назначение

Данный программный продукт позволяет выполнять 3 основных действия:

1. «Обучение и тестирование» - в данном пункте предлагается изучить алгоритм шифрования ГОСТ 28147-89 (в режиме гаммирования), в ходе последовательных шагов обучения. Для этого необходимо ввести открытый текст, ключ и синхропосылку, служащую для рандомизации процесса шифрования. После прохождения всех необходимых этапов

показывается результат, который при необходимости можно сохранить и впоследствии проанализировать процесс обучения.

2. «Шифрование файла» - в данном пункте можно зашифровать или расшифровать любой файл, одним из возможных способов: простая замена; гаммирование; гаммирование с обратной связью. После выполнения действий выдается статистика о скорости чтения, шифрования, и записи информации.

3. «Шифрование с клавиатуры» - в данном пункте можно зашифровать или расшифровать любой текст, введенный с клавиатуры, одним из возможных способов: простая замена; гаммирование; гаммирование с обратной связью.

Режим ввода организован таким образом, что данные можно вводить как в символьном представлении, так и в шестнадцатиричном.

2.3. Описание алгоритма работы программы

После запуска приложения ГОСТ89.ехе загружается главная форма программы. В данной форме вводятся первоначальные данные: ключ (32 байта), синхропосылка (8 байт) и предлагается выбрать режим работы программы: «Обучение и тестирование», «Шифрование файла» или «Шифрование с клавиатуры» (рис. 1). Переключение между режимами осуществляются с помощью закладок.

В режиме «Обучение и тестирование» можно пройти все этапы обучения или просмотреть предыдущие результаты тестирования. Для выбора режима обучения необходимо ввести открытый текст и нажать кнопку «Начать тест». Для выбора просмотра результатов предыдущих тестирований необходимо нажать кнопку «Загрузить результат». После нажатия на кнопку «Начать тест» открывается окно теста, сам тест разбит на 12 последовательных шагов, с подробным описанием действий, которые нужно сделать, и диаграммой, на которой графически отображается необходимый шаг обучения. Кроме подробного описания на форме( в большинстве шагов) присутствует кнопка «Демонстрация», с помощью которой можно получить дополнительную подсказку. Для перехода на следующий шаг необходимо нажимать кнопку «Далее>>», для возврата на предыдущий шаг кнопку ««Назад» (рис. 2).

Рис 1. Главная форма программы

ида*»«* е реки« -¡мие&нт Разделение аргумента гсо 32 бита

хит ОНОПШТИ 8 СОШ№ и> ЗаУЮОШО

5 = СО* илсл змдао» ? Ь гс< за |Щ19||ч 1ши «звеог^' [в^и*** г«?«I

пос1аавггел*«стм \ty\i' РГПЧ1 ■ ■1 и_I (-ехс-шмз ¿ьгге на » ниоже 32

53 = 1п,гт—ТЛ 5

ачаисгниар1

8»($1.80|

Ис«однэя посяе&овштеяйюстъ бмтм 5

|пои111 оиссоп относ :1:о1:о: Ю130301 1:001150 осисюло оояюш Стаж 32 №51 Мглиии32б«тз50

5 = ССН 11ЖП 51ЛИО=

Ю-6ЩТ:

Рис. 2. Шаг №1 в режиме «Обучение и тестирование»

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

Рис. 3. Результат тестирования При желании можно сохранить результат тестирования.

Рис. 4. Сохранение результатов тестирования

В режиме «Шифрование файла» можно зашифровать или расшифровать файл любого формата. Для этого необходимо ввести ключ и син-хропосылку (в режиме «простой замены» синхропосылка не использу-

ется). Также необходимо ввести имя файла с открытыми данными и имя файла для зашифрованного результата. Для начала шифрования необходимо нажать кнопку «Зашифровать/Расшифровать». После выполнения шифрования/расшифрования выводится статистика о времени и скорости выполнения.

Рис. 5. Главная форма режима шифрования файлов

Для работы в режиме «Шифрование с клавиатуры» необходимо ввести ключ, синхропосылку и открытый текст. Далее нажать кнопку «Зашифровать/Расшифровать». После выполнения шифрования/расшифрования на экран выводится обработанная информация. Данные можно вводить как в символьном, так и в шестнадцатиричном представлении. В режиме простой замены длина обрабатываемой информации должна быть кратна 8 символам.

uni ni i ' "■' »""'■' .4'—^^

» — IV fc* .4

( ii'irjKl'rftfl «rictflt 1ГМШ1' |a(V4>r|il>4*f» (M Г«1Г «>011 HC I ■*>•> •*»k( (m« mm» »1» С .......... * lu «MM I

• Il 1ГИ1 lUInn I СИП>»И1

0»|MIH«I». .JIII-I .................."4 I

а-мрмя сшм* » г f*м««»«ч Г Горст«ч мим «С Г »..<■»«.« С Г<«— < «фгяа .■■> и UlflMTMÜ (МП

го i« •о r.HU"«?"»*

••• ■ш «■ го •С «4 1« » (1 г» ж о 1 «а п г» п щ •( е.- и 1 I« n it >о И П Г) К а м г • р Г* II г* • ou ia с» M* «||14*

ü . -L. „ ■

V*l tu ШШ 1 И«1к • •i 14 » К м г II *Л >t M ("TZ V2 ¡Л Т7 }» ТУ 1* л ¿У ff V (S <1 П К |< m •«>•'. f «• Ц -< •« • * ''Г ГГ •( 17 ГО U «• 4* il «О О» 0> • • lu ii <[t > > im it «г «• v ;i » •• Mi -V ■> Cf •« H IU M К 1' •• «• «К »i er м na о " »i •• л» ^ II « К 1П я! • 1 w. •» »• it in о* rt »t Ii IX .4 «* fl (• •> .«•>•) » i »r , J . МД' * n \м» : M

» А«г*лм цНг«- i«.J« *

Рис. 6. Главная форма режима шифрования с клавиатуры

Обучающая программа дает возможность пользователю детально разобраться в алгоритме шифрования ГОСТ 28147-89, на ее основе можно организовать проведение лабораторной работы. Данная разработка может служить основой для создания обучающих программ по другим алгоритмам, использующим сходные шаги (арифметические и логические операции, битовые перестановки, замены, сдвиги, модулярную арифметику).

Литература

1. Кабанов Е. В. Программа обучения алгоритму шифрования DES / Е. В. Кабанов, М. В. Прокопов [электронный ресурс], 2001г. -(http://www.blackw.des.ru, [email protected])

2. Витер В. Обучающая программа El-Gamal. Версия 1.0 / В. Витер [электронный ресурс], 1999 г. - ( [email protected]).

3. Вычисления, полезные в криптографии : Crypto03.exe, v. 10.11.03 [электронный ресурс]. - Ставрополь : КубГТУ, 2003.

4. Воронков Б. Н. Разработка обучающей программы по изучению российского стандарта шифрования ГОСТ 28147 - 89 / Б. Н. Воронков, И. А. Терпугов // Из режима функционирования - в режим развития: сб. н. тр. регион. межвуз. НПК 23 - 26 апреля 2007 г. В 2 - х частях. - Воронеж : ВФ МГЭИ, 2007. - Ч. 2. - С. 14 - 20.

5. Система обработки информации. Защита криптографическая. Алгоритм криптографического преобразования. ГОСТ 28147 - 89. - М. : ИПК издательство стандартов, 1996. - 28 с.

6. Хоффман Л. Дж. Современные методы защиты информации : Пер. с англ. Под ред. В. А. Герасименко / Л. Дж. Хоффман . - М. : Советское радио, 1980. - 264 с.

i Надоели баннеры? Вы всегда можете отключить рекламу.