FEAL

FEAL (англ. Fast data Encipherment ALgorithm) — блочный шифр, разработанный Акихиро Симидзу и Сёдзи Миягути — сотрудниками компании NTT.

FEAL
Создатель Акихиро Симидзу и Сёдзи Миягути (NTT)
Опубликован FEAL-4 в 1987; FEAL-N/NX в 1990
Размер ключа 64 бит (FEAL), 128 бит (FEAL-NX)
Размер блока 64 бит
Число раундов изначально 4, потом 8 и потом переменное количество (рекомендуемое — 32)
Тип Сеть Фейстеля

В нём используются 64-битовый блок и 64-битовый ключ. Его идея состоит и в том, чтобы создать алгоритм, подобный DES, но с более сильной функцией этапа. Используя меньше этапов, этот алгоритм мог бы работать быстрее. К тому же, в отличие от DES, функция этапа для FEAL не использует S-блоки, поэтому реализация алгоритма не требует дополнительной памяти для хранения таблиц замены[1].

История править

Опубликованный в 1987 году Акихиро Симидзу и Сёдзи Миягути блочный шифр FEAL был разработан с целью повысить скорость шифрования без ухудшения надежности шифра, по сравнению с DES. Первоначально алгоритм использовал блоки размером 64 бита, ключ размером 64 бита и 4 раунда шифрования. Однако, уже в 1988 году была опубликована работа Берта ден Боера (англ. Bert Den-Boer) , доказывающая достаточность владения 10000 шифротекстов для проведения успешной атаки на основе подобранного открытого текста[2]. К шифру FEAL одному из первых был применен линейный криптоанализ. В том числе в 1992 году Митсуру Мацуи и Ацухиро Ямагиси доказали, что достаточно узнать 5 шифротекстов для проведения успешной атаки[3].

Для борьбы с обнаруженными уязвимостями создатели удвоили число раундов шифрования, опубликовав стандарт FEAL-8. Однако, уже в 1990 году Генри Гилберт (англ. Henri Gilbert) обнаружил уязвимость и этого шифра перед атакой на основе подобранного открытого текста[4]. Далее в 1992 году Мицуру Мацуи и Ацухиро Ямагиси (Mitsuru Matsui and Atsuhiro Yamagishi) описали атаку на основе открытых текстов, требующую   известных шифротекстов[3].

В связи с большим числом успешных атак, разработчиками было принято решение еще усложнить шифр. А именно, в 1990 году был представлен FEAL-N, где N — произвольное четное число раундов шифрования, и представлен FEAL-NX, где X (от англ. extended) обозначает использование расширенного до 128 бит ключа шифрования. Однако данное нововведение помогло лишь частично. В 1991 году Эли Бихам и Ади Шамир, используя методы дифференциального криптоанализа, показали возможность взлома шифра с числом раундов   быстрее, чем полным перебором[5].

Тем не менее, благодаря интенсивности исследования алгоритма шифрования сообществом, были доказаны границы уязвимости шифра перед линейным и дифференциальным криптоанализом. Устойчивость алгоритма с числом раундов большим 26 к линейному криптоанализу показали в своей работе Сихо Мораи, Кадзумаро Аоки и Кадзуо Ота[6], а в работе Казумаро Аоки, Кунио Кобаяси и Шихо Мораи была доказана невозможность применить дифференциальный криптоанализ к алгоритму, использующему больше 32 раундов шифрования[7].

Описание править

В качестве входа процесса шифрования в алгоритме FEAL-NX используется 64-битовый блок открытого текста[1][8]. Процесс шифрования разбит на 3 стадии.

  1. Предобработка
  2. Итеративное вычисление
  3. Постобработка

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

Определим (A,B) — операцию конкатенации двух последовательностей бит.

Определим   — нулевой блок длины 32 бита.

Функция S править

  = циклический сдвиг влево на 2 бита  

  = циклический сдвиг влево на 2 бита  

Функция F править

 
Схема функции F

Функция F берёт 32 бита данных и 16 битов ключа и смешивает их вместе.

  1.  
  2.  
  3.  
  4.  
  5.  
  6.  
  7.  
  8.  
  9.  
  10.  

Функция   править

 
Схема функции  

Функция   работает с двумя 32 битовыми словами.

  1.  
  2.  
  3.  
  4.  
  5.  
  6.  
  7.  
  8.  

Генерация раундовых ключей править

 
Схема генерации раундовых ключей

В результате генерации раундовых ключей, из полученного на вход ключа длиной 128 бит получается набор из N+8 раундовых ключей  , длиной 16 бит каждый. Данный результат получается в результате следующего алгоритма.

  1. Разделение входного ключа на левый и правый ключ:  , они имеют длину 64 бита.
  2. Обработка ключа  
  3. Введение временной переменной   для  :
    •  
    •  
    •  
  4. Обработка ключа  
  5. Введение временной переменной  
  6. Последовательное вычисление  
    1.  
    2.  
    3.  
    4.  
    5.  

Предобработка править

На начальной стадии блок данных   готовится к итеративной процедуре шифрования.

  1.  
  2.  
  3.  

Итеративная обработка править

На этой стадии с блоком данных производится N раундов перемешивания битов по следующему алгоритму.

  1.  
  2.  

Постобработка править

Задача этой стадии — подготовить почти готовый шифротекст к выдаче.

  1.  
  2.  
  3.  

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

Применение править

Хотя изначально алгоритм FEAL задумывался, как более быстродействующая замена DES, в том числе, для применения шифрования в смарт-картах, количество быстро найденных в нем уязвимостей поставило точку на перспективах использования данного алгоритма. К примеру, в работе Эли Бихама и Ади Шамира, опубликованной в 1991 году, доказана достаточность 8 выбранных открытых текстов для взлома шифра FEAL-4, 2000 — для взлома FEAL-8,   — для FEAL-16[5]. Все эти числа значительно меньше необходимого числа выбранных открытых текстов для атаки на DES, а тот факт, что FEAL-32 достаточно надежен, достаточно бесполезен, так как DES добивается сравнимой надежности при значительно меньшем числе раундов, тем самым лишая FEAL преимущества, изначально задумывавшегося создателями.

На данный момент на официальном сайте авторов шифра — компании NTT, в описании шифра FEAL вывешено предупреждение, о том что компания NTT рекомендует не использовать шифр FEAL, а использовать шифр Camelia, также разработанный этой компанией ради надежности и скорости шифрования[9].

Вклад в развитие криптографии править

Благодаря тому, что шифр FEAL был разработан достаточно рано, он послужил отличным объектом для тренировок для криптологов всего мира[10].

Кроме того, на его примере был открыт линейный криптоанализ. Мицуру Мацуи[en], изобретатель линейного криптоанализа, в первой своей работе на эту тему рассматривал как раз FEAL и DES.

Примечания править

  1. 1 2 Панасенко, 2009.
  2. Boer, 1988.
  3. 1 2 Matsui, Yamagishi, 1992.
  4. Gilbert, Chassé, 1990.
  5. 1 2 Biham, Shamir, 1991.
  6. Kazuo Ohta, Shiho Moriai, Kazumaro Aoki. Improving the Search Algorithm for the Best Linear Expression // Proceedings of the 15th Annual International Cryptology Conference on Advances in Cryptology. — London, UK, UK: Springer-Verlag, 1995-01-01. — С. 157–170. — ISBN 3540602216.
  7. Aoki, Kobayashi, Moriai, 1997.
  8. Спецификация алгоритма шифрования FEAL-N(NX). Дата обращения: 3 декабря 2016. Архивировано 23 января 2021 года.
  9. NTT Encryption Archive List. info.isl.ntt.co.jp. Дата обращения: 27 ноября 2016. Архивировано из оригинала 7 октября 2016 года.
  10. Шнайер Б. Курс самоподготовки по криптоанализу блочных шифров. — Пер. с англ.Быбин С.С.. Архивировано 2 апреля 2022 года.

Литература править