Misplaced Pages

User:Владимир Дубихин/sandbox

Article snapshot taken from Wikipedia with creative commons attribution-sharealike license. Give it a read and then ask your questions in the chat. We can research this topic together.

Дифференциальный криптоанализ — метод криптоанализа симметричных блочных шифров (и других криптографических примитивов, в частности, хэш-функций). Предложен в 1990 году израильскими специалистами Эли Бихамом и Ади Шамиром.

Дифференциальный криптоанализ основан на изучении преобразования разностей между шифруемыми значениями на различных раундах шифрования. В качестве разности, как правило, применяется операция побитового суммирования по модулю 2, хотя существуют атаки и с вычислением разности по модулю 2 32 {\displaystyle 2^{32}} . Является статистической атакой, в результате работы предлагает список наиболее вероятных ключей шифрования блочного симметричного шифра.

Дифференциальный криптоанализ применим для взлома DES, FEAL и некоторые других шифров, как правило, разработанных ранее начала 90-х. Количество раундов современных шифров (AES, Camellia и др.) рассчитывалось с учетом обеспечения стойкости в том числе и к дифференциальному криптоанализу.

Дифференциальный криптоанализ DES

В 1990 году Эли Бихам и Ади Шамир используя метод дифференциального криптоанализа нашли способ вскрытия DES, более эффективный, чем вскрытие методом грубой силы. Работая с парами шифротекстов, открытые тексты которых имеют определенные отличия, ученые анализировали эволюцию этих отличий при прохождении открытых текстов через этапы DES.

Схема взлома

Дифференциальный криптоанализ|frame|

Рис.1 Схема взлома

|right На схеме представлено прохождение одного из этапов DES. Пусть X и X' - пара входов, различающихся на ΔX. Соответствующие им выходы известны и равны Y и Y', разница между ними - ΔY. Также известны перестановка с расширением и P-блок, поэтому известны ΔA и ΔC. B и B' неизвестны, но мы знаем, что их разность равна ΔA, т.к. различия XOR Ki c A и A' нейтрализуются. Вскрытие ключа основано на том факте, что для заданного ΔA не все значения ΔC равновероятны, а комбинация ΔA и ΔC позволяет предположить значения A XOR Ki и A' XOR Ki. При известных A и A' это дает нам информацию о Ki.

Таким образом, определенные отличия пар открытых текстов с высокой вероятностью вызывают определенные отличия получаемых шифротекстов. Такие различия называют характеристиками. Для нахождения характеристик составляется таблица, в которой строкам соответствуют возможные ΔX, столбцам - возможные ΔY, а на пересечении строки и столбца пишется, сколько раз заданное ΔY встречается для заданного ΔX. Различные характеристики можно объединять, и, при условии, что рассматриваемые этапы независимы, перемножать их вероятности.

Пара открытых текстов, которая соответствует характеристике называется правильной парой, а пара, не соответствующая характеристике - неправильной парой. Правильная пара указывает на правильный ключ рассматриваемого этапа, неправильная - на случайный ключ. Для нахождения правильного ключа этапа нужно собрать достаточное количество предположений - один из ключей будет встречаться среди правильных чаще, чем остальные. Зная вероятное значение Ki мы получаем 48 битов ключа шифрования K. Остальные 8 битов можно определить с помощью перебора.

Эффективность взлома

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

Бихам и Шамир предложили вместо 15-этапной характеристики 16-этапного DES использовать 13-этапную характеристику и с помощью ряда приемов получать данные для последних этапов. Кроме того, они использовали специальные оптимизации для получения вероятных 56-битовых ключей, что позволяло проверять их немедленно. Это решало проблему с пороговым характером взлома и устраняло необходимость в хранении счетчиков.

Наилучший разработанный алгоритм дифференциального вскрытия полного 16-этапного DES требует 2 выбранных открытых текстов. При этом временнная сложность составляет 2 операций DES.

Дифференциальный криптоанализ применим для взлома алгоритмов с постоянными S-блоками, таких как DES. При этом его эффективность сильно зависит от структуры S-блоков. Оказалось, что S-блоки DES оптимизированы против дифференциального криптоанализа. Предполагается, что создатели DES знали об этом методе. По словам Дона Копперсмита из IBM:

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

Повышение устойчивости к взлому

Устойчивость DES к дифференциальному криптоанализу может быть повышена путем увеличения количества этапов. Дифференциальный криптоанализ для DES с 17 или 18 этапами потребует столько же времени, сколько и полный перебор, а при 19 или более этапах дифференциальный криптоанализ невозможен (т.к. для него потребуется более чем 2 открытых текстов, что невозможно при длине блока 64 бита).

Недостатки метода

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

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

Сравнение с другими методами

См. Известные атаки на DES

Cпециализированные типы дифференциального криптоанализа:

  1. Укороченный дифференциальный криптоанализ.
  2. Дифференциальный криптоанализ с дифференциалами высших порядков.

Укороченный дифференциальный криптоанализ.

В стандартном диффернциальном криптоанализе пара (ΔX,ΔY) четко задана. Однако, можно провести атаку, для которой не надо знать полное выходное различие, достаточно лишь несколько бит.

Дифференциальный криптоанализ с дифференциалами высших порядков.

Данный тип криптоанализа был разработан Ларсом Кнудсеном в 1994. Данный метод является обобщением дифференциального криптоанализа.

Дифференциалом 1-го порядка булевой функции f ( x ) {\displaystyle f(x)} называется дифференциал вида Δ s f ( x ) = f ( x + s ) f ( x ) {\displaystyle {\Delta }_{s}f(x)=f(x+s)-f(x)} . Для поля Галуа GF(2) Δ s f ( x ) = f ( x ) f ( x s ) {\displaystyle _{s}f(x)=f(x)\oplus f(x\oplus s)}

Понятие дифференциала i-го порядка вводитися рекурсивно Δ ( a 1 , . . . , a i ) i f ( x ) = Δ a i ( Δ ( a 1 , . . a i 1 ) i f ( x ) ) ) {\displaystyle \Delta _{(a_{1},...,a_{i})}^{i}f(x)=\Delta _{a_{i}}(\Delta _{(a_{1},..a_{i-1})}^{i}f(x)))}

Рассмотрим атаку на 5-раундовую сеть Фейстеля с функцией f ( x , k ) = ( x + k ) 2 m o d p {\displaystyle f(x,k)=(x+k)^{2}modp} и независимыми ключами:

  1. Выберем один открытый текст P 1 {\displaystyle P_{1}}
  2. Составим 3 дополнительных текста P 2 = P 1 + α , P 3 = P 1 + β , P 4 = P 1 + α + β {\displaystyle P_{2}=P_{1}+\alpha ,P_{3}=P_{1}+\beta ,P_{4}=P_{1}+\alpha +\beta } , где α = a | | 0 , β = b | | 0 {\displaystyle \alpha =a||0,\beta =b||0} (a,b-левые части)
  3. Найдем соотвествующие P i {\displaystyle P_{i}} шифротексты C i {\displaystyle C_{i}}
  4. Для каждого значения k 5 {\displaystyle k_{5}} ключа R K 5 {\displaystyle RK_{5}} :
    1. Расшивровать шифротексты C i {\displaystyle C_{i}} , используя ключ k 5 {\displaystyle k_{5}} . Обозначим их как D i {\displaystyle D_{i}}
    2. Для каждого значения k 4 {\displaystyle k_{4}} ключа R K 4 {\displaystyle RK_{4}} :
      1. Рассчитать t i = f ( D i R + k 4 ) {\displaystyle t_{i}=f(D_{i}^{R}+k_{4})}
      2. Если ( t 1 + t 4 ( t 2 + t 3 ) ) ( D 1 L + D 4 L ( D 2 L + D 3 L ) ) = 2 a b {\displaystyle (t_{1}+t_{4}-(t_{2}+t_{3}))-(D_{1}^{L}+D_{4}^{L}-(D_{2}^{L}+D_{3}^{L}))=2*a*b} , то распечатать значения k 4 {\displaystyle k_{4}} и k 5 {\displaystyle k_{5}}

См. также

Примечания

  1. Для алгоритма DES термин "отличие" определяется как результат применения операции XOR

Ссылки


Категория:Криптографические атаки en:Differential cryptanalysis

User:Владимир Дубихин/sandbox Add topic