ISAAC (шифр) - ISAAC (cipher)

ИСААК (косвенное обращение, сдвиг, накопление, добавление и подсчет) это криптографически безопасный генератор псевдослучайных чисел и потоковый шифр разработано Роберт Дж. Дженкинс мл. в 1993 г.[1] В эталонная реализация исходный код был посвящен всеобщее достояние.[2]

Операция

ISAAC алгоритм имеет сходство с RC4. Он использует множество 256 четырехоктетных целые числа в качестве внутреннего состояния, запись результатов в другой массив из 256 четырехоктетных целочисленных значений, из которого они считываются по одному до тех пор, пока не станут пустыми, после чего они пересчитываются. Вычисление состоит из изменения я-элемент с (я⊕128) -элемент, два элемента массива состояний, найденных косвенно, аккумулятор и счетчик, для всех значений я от 0 до 255. Поскольку для каждого 32-битного выходного слова требуется всего около 19 32-битных операций, это очень быстро на 32-битных компьютерах.

Криптоанализ

Криптоанализ была предпринята Мариной Пудовкиной (2001).[3] Ее атака может восстановить исходное состояние со сложностью, которая приблизительно меньше времени, необходимого для поиска квадратного корня из всех возможных начальных состояний. На практике это означает, что атака требует вместо . Этот результат не оказал практического влияния на безопасность ISAAC.[4]

В 2006 году Жан-Филипп Аумассон обнаружил несколько наборов слабых состояний.[5] Четвертый представленный (и самый маленький) набор слабых состояний приводит к сильно смещенному выходу для первого раунда ISAAC и позволяет вывести внутреннее состояние, подобное слабость в RC4. Неясно, может ли злоумышленник определить только по выходным данным, находится ли генератор в одном из этих слабых состояний или нет. Он также показывает, что предыдущая атака[6] ошибочен, поскольку Павел -Preneel атака основана на ошибочном алгоритме, а не на реальном ISAAC. Предлагается улучшенная версия ISAAC, названная ISAAC +.[4]

Использование вне криптографии

Многие реализации ISAAC настолько быстры, что могут конкурировать с другими высокоскоростными PRNG, даже с теми, которые разработаны в первую очередь для скорости, а не для безопасности. Лишь несколько других генераторов такого высокого качества и скорости используются. ISAAC используется в инструменте Unix. крошить для безопасной перезаписи данных.[7]

Рекомендации

  1. ^ Роберт Дж. Дженкинс младший, ISAAC. Быстрое шифрование программного обеспечения 1996, стр. 41–49.
  2. ^ Шифр ISAAC
  3. ^ Марина Пудовкина, Атака с использованием известного открытого текста на генератор ключевого потока ISAAC, 2001, Архив Cryptology ePrint: Отчет 2001/049, [1].
  4. ^ а б «О псевдослучайном генераторе ISAAC» (PDF). Архив криптологии ePrint. Получено 21 августа 2016.
  5. ^ Жан-Филипп Аумассон, О псевдослучайном генераторе ISAAC. Архив Cryptology ePrint, отчет 2006/438, 2006.
  6. ^ Сурадьюти Пол, Барт Пренил, О (не) безопасности потоковых шифров, основанных на массивах и модульном сложении, Asiacrypt 2006.
  7. ^ GNU coreutils git

внешняя ссылка