ЛОГИКА ПОСТРОЕНИЯ ШИФРА И СТРУКТУРА КЛЮЧЕВОЙ ИНФОРМАЦИИ ГОСТ 28147–89 - Студенческий научный форум

XI Международная студенческая научная конференция Студенческий научный форум - 2019

ЛОГИКА ПОСТРОЕНИЯ ШИФРА И СТРУКТУРА КЛЮЧЕВОЙ ИНФОРМАЦИИ ГОСТ 28147–89

 Комментарии
Текст работы размещён без изображений и формул.
Полная версия работы доступна во вкладке "Файлы работы" в формате PDF

Если внимательно изучить оригинал ГОСТ 28147–89, можно заметить, что в нем содержится описание алгоритмов нескольких уровней. На самом верхнем находятся практические алгоритмы, предназначенные для шифрования массивов данных и выработки для них имитовставки. Все они опираются на три алгоритма низшего уровня, называемые в тексте ГОСТа циклами. Эти фундаментальные алгоритмы упоминаются в данной статье как базовые циклы, чтобы отличать их от всех прочих циклов. Они имеют следующие названия и обозначения, последние приведены в скобках и смысл их будет объяснен позже:

цикл зашифрования (32-З);

цикл расшифрования (32-Р);

цикл выработки имитовставки (16-З).

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

Таким образом, чтобы разобраться в ГОСТе, надо понять три следующие вещи:

что такое основной шаг криптопреобразования;

как из основных шагов складываются базовые циклы;

как из трех базовых циклов складываются все практические алгоритмы ГОСТа.

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

Ключ является массивом из восьми 32-битовых элементов кода, далее в настоящей работе он обозначается символом K:  . В ГОСТе элементы ключа используются как 32-разрядные целые числа без знака: . Таким образом, размер ключа составляет 32·8=256 бит или 32 байта.

Таблица замен является вектором, содержащим восемь узлов замены . Каждый узел замены, в свою очередь, является вектором, содержащим шестнадцать 4-битовых элементов замены, которые можно представить в виде целых чисел от 0 до 15, все элементы одного узла замены обязаны быть различными. Таким образом, таблица замен может быть представлена в виде матрицы размера 8x16 или 16x8, содержащей 4-битовые заменяющие значения. Для языков программирования, в которых двумерные массивы расположены в оперативной памяти по строкам, естественным является первый вариант (8x16), его-то мы и возьмем за основу. Тогда узлы замены будут строками таблицы замен. В настоящей статье таблица замен обозначается символом H: ,  . Таким образом, общий объем таблицы замен равен: 8 узлов x 16 элементов/узел x 4 бита/элемент = 512 бит = 64 байта.

{\displaystyle DES_{k1}(DES_{k2}(x)) = x}

Использованные источники:

Алгоритмы шифрования. Специальный справочник. / Сергей Панасенко, - БХВ-Петербург, 2009 -257 с.

Информационная безопасность и защита. Учебное пособие. / Елена Баранова, Александр Бабаш, - Инфра-М, 2017 -324 с.

Основы информационной безопасности. Учебное пособие. / Сергей Нестеров, - Лань, 2016 – 324 с.

Просмотров работы: 33