CBC-MAC: различия между версиями

Материал из Википедии — свободной энциклопедии
Перейти к навигации Перейти к поиску
[отпатрулированная версия][отпатрулированная версия]
Содержимое удалено Содержимое добавлено
статья помечена как некатегоризированная с помощью AWB
категория, интервики
Строка 175: Строка 175:


== Безопасность семейства OMAC ==
== Безопасность семейства OMAC ==

=== Определение защищённости ===
=== Определение защищённости ===
Пусть Perm(n) означает набор всех перестановок из <math>\{0, 1\}^n</math>, так же пусть P является случайной перестановкой, если Р — случайная выборка из Perm(n). Безопасность блочного шифра E может быть количественно определена как <math>Adv^{prp}_E(t, q)</math>, максимальное преимущество, которое противник A может получить, когда пытается выделить <math>E_K( \cdot )</math> (со случайно выбранным ключём K) из случайной перестановки P(•), когда допускается вычисление времени t и q запросов (который является либо <math>E_K(\cdot)</math> либо <math>P(\cdot)</math>). Это преимущество определяется следующим образом.
Пусть Perm(n) означает набор всех перестановок из <math>\{0, 1\}^n</math>, так же пусть P является случайной перестановкой, если Р — случайная выборка из Perm(n). Безопасность блочного шифра E может быть количественно определена как <math>Adv^{prp}_E(t, q)</math>, максимальное преимущество, которое противник A может получить, когда пытается выделить <math>E_K( \cdot )</math> (со случайно выбранным ключём K) из случайной перестановки P(•), когда допускается вычисление времени t и q запросов (который является либо <math>E_K(\cdot)</math> либо <math>P(\cdot)</math>). Это преимущество определяется следующим образом.
Строка 184: Строка 185:
<br />
<br />
Скажем, что блочный шифр E — защищён, если существенно мало. Аналогично, MAC-алгоритм — F : <math>K_F</math> × <math> \{0, 1\}^n</math> → <math>\{0, 1\}^n</math>, где <math>K_F</math> — набор ключей, тогда запишем <math>F_K(\cdot)</math> для F(K, •). Скажем, что противник <math>A^{F_K(\cdot)}</math> взламывает, если A выдаёт <math>(M,F_K(M))</math>, где A никогда не запрашивает M из <math>F_K(\cdot)</math>.
Скажем, что блочный шифр E — защищён, если существенно мало. Аналогично, MAC-алгоритм — F : <math>K_F</math> × <math> \{0, 1\}^n</math> → <math>\{0, 1\}^n</math>, где <math>K_F</math> — набор ключей, тогда запишем <math>F_K(\cdot)</math> для F(K, •). Скажем, что противник <math>A^{F_K(\cdot)}</math> взламывает, если A выдаёт <math>(M,F_K(M))</math>, где A никогда не запрашивает M из <math>F_K(\cdot)</math>.
Тогда мы определяем преимущество как
Тогда мы определяем преимущество как


<math>
<math>
Строка 245: Строка 246:
|isbn =
|isbn =
}}
}}

{{нет категорий}}
[[Категория:Блочные шифры]]
[[Категория:Аутентификация]]

[[fr:CBC-MAC]]
[[en:CBC-MAC]]
[[it:CBC-MAC]]

Версия от 19:44, 30 ноября 2010

В криптографии, CBC MAC является технологией построения аутенфикационного кода сообщения из блочного шифра. Сообщение шифруется при помощи некоторого блочного алгоритма шифрования в режиме CBC, для создания цепочки блоков с правилом — каждый блок зависит от надлежащего(верного) шифрования предыдущего. Эта взаимозависимость гарантирует, что изменение в любом бите открытого текста приведёт к изменению конечного зашифрованного блока в сторону, которая не может быть предсказана или высчитана в случае, если ключ блочного шифра не известен.

Справочная информация

Алгоритм CBC MAC является хорошо известным методом для генерации имитовставки (имитовставка, англ. message authentication code — код аутентичности сообщения), основанный на блочном шифре. Bellare, Kilian и Rogaway доказали безопасность (защищённость) алгоритма при фиксированной длине сообщения в m*n бит, где n — длина базового блочного шифра Е [1]. Однако, хорошо известно, что CBC MAC не является безопасным, если длина сообщения не является фиксированной. Таким образом, было предложено несколько вариантов алгоритма для варьируемой длины сообщения. Сначала была предложена зашифрованная имитовставка(EMAC). Она получается шифрованием CBC MAC значения с помощью E и новым ключом . То есть , где M — сообщение,  — ключ CBC MAC и  — значение CBC MAC сообщения М [1]. Petrank и Rackoff позже доказали, что EMAC защищён, если длина сообщения кратна n [11] (Vaudenay используя декорреляционную теорию, опубликовал другое доказательство [14]). Однако, EMAC требует два ключевых расписания базового блочного шифра E. Далее Black и Rogaway предложили XCBC, который требует только одного ключевого расписания базового блочного шифра E [3]. XCBC даёт три ключа: один ключ блочного шифра K1, и два ключа по n бит. XCBC описывается следующей схемой

На таблице приведено сравнение длин ключей.

XCBC [3] TMAC [9] OMAC
Длина ключа (k + 2n) бит (k + n) бит k бит

Если для некоторого m > 0, то XCBC вычисляется в точности, как и CBC MAC, за исключением операции XOR(«исключающее или») ключа (n бит) до шифрования последнего блока.

В противном случае, (где ) добавляется к М и XCBC вычисляется в точности, как и CBC MAC для полученного сообщения. За исключением операции XOR другого ключа (n бит) до шифрования последнего блока. Однако, недостатком XCBC заключается в требовании трёх ключей, то есть в сумме (k + 2n) бит. В итоге, Kurosawa и Iwata предложили двуключевой CBC MAC (TMAC) [9]. TMAC принимает два ключа, в сумме (k + n) бит: ключ блочного шифра и ключ (n бит). TMAC получается из XCBC перемещением (или заменой) на , где u — некоторая ненулевая константа, а «•» обозначает умножение в . Как уже было сказано, OMAC (one-key CBC MAC) принимает только один ключ К блочного шифра Е. Длина ключа, k бит, минимальна, так как базовый шифр должен содержать ключ K, состоящий из k бит в любом случае.

OMAC

OMAC является родительским названием для OMAC1 и OMAC2. OMAC1 получается из XCBC с помощью замены на для некоторой не равной нулю константе u в , где L — даётся с помощью следующего выражения: . OMAC2 аналогично получается используя . Мы можем вычислть , и эффективно одним сдвигом и условием XOR на и , соответственно. OMAC1 (соотв. OMAC2) описывается следующей схемой:


1. Если для некоторого m > 0, тогда OMAC вычисляется в точности, как CBC MAC, за исключением операции XOR для до шифрования последнего блока.
2. В противном случае, (где ) добавляется к M и OMAC Вычисляется в точности, как CBC MAC для полученного сообщения М, за исключением операции XOR для (соотв. до шифрования последнего блока.

Кроме того, в TMAC, ключ является частью ключа, в то время как в OMAC, L не является частью ключа и генерируется из K. Эта сохранность длины ключа делает доказательство безопасности OMAC значительно сложнее чем для TMAC, как показано ниже. На рисунке 2, пусть M[1] = . Тогда L является выходом первого . L всегда появляется снова в последнем блоке. В основном, подобное повторное использование L могло бы привести к тупику в доказательстве безопасности. (В OCB режиме[13] и PMAC[5], так же используется как ключ универсальной хэш-функции. Однако L появляется как выход некоторого внутреннего блока с незначительной вероятностью.) Тем не менее, мы доказали, что OMAC является таким же защищённым как и XCBC, где анализ безопасности является образцом абсолютной защищённости [1]. Дальнейший OMAC получил все другие положительные свойства, которыми были наделены XCBC (и TMAC). Таким образом, область OMAC — {0,1}, необходимо одноключевое расписание базового блочного шифра E и блочно-шифровых вызовов(обращений).

Обозначения

Для набора A, x←A означает, что x выбирается из A случайно, причём выбор любого значения из набора А является равновероятным. Если a, b (∈ {0, 1}*) равновеликие строки, тогда a ⊕ b является их побитовой операцией XOR. Если a, b (∈ {0, 1}*) не равновеликие строки, то a ◦ b обозначает их конкатенацию. (Для упрощения далее вводится обозначение: ab:= a ◦ b). Для n-битной строки ∈ {0, 1}*, обозначим << 1 = n-битную строку, которая сдвинута влево на 1 бит, в это же время обозначим a >> 1 = n-битную строку, которая сдвинута вправо на один бит. Если a ∈ {0, 1}* является строкой, то |a| обозначим её битовую длину. Для любого бита строка a ∈ {0, 1}* такова что |a| ≤ n, положим что

Определим , где пустая строка считается как один блок.

CBC MAC

Блочный шифр Е является функцией Е : × , где каждое E(K, •) = EK(•) является перестановкой , в свою очередь является набором всевозможных ключей, а n — длина блока. CBC MAC [6, 7] является наипростейшим и наиболее известным алгоритмом, для того что бы сделать MAC из блочного шифра Е. Пусть сообщение будет иметь вид M = M[1] ◦M[2] ◦ … ◦M[m], где |M[1]| = |M[2]| = … = |M[m]| = n. Тогда CBCK(M), CBC MAC сообщения M при условии ключа K, определяется как Y [m], где Y [i] = EK(M[i] ⊕ Y [i − 1]) для i = 1, … ,m и Y [0] = . Bellare, Kilian и Rogaway доказали безопасность CBC MAC для фиксированной длины сообщения в mn бит [1].

Поле с точками

Мы вправе рассматривать точку a в любым из следующих способов: (1) как абстрактная точка в поле а; (2) как n-битную строку ; (3) как формальный полином с бинарными коэффициентами. Для того что бы добавить 2 точки в , рассмотрим битовую операцию ХOR над ними. Обозначим эту операцию с помощью a ⊕ b. Для того что бы перемножить две точки, зафиксируем некоторый полином f(u) с бинарными коэффициентами и степенью n. Для большей точности, выберем лексикографически первым полином среди таких же полиномов степени n имеющий минимальное число коэффициентов. Перечислим некоторые из указанных полиномов
для n = 64,
для n = 128, и
для n = 256.
Для того, что бы перемножить две точки a и b, рассмотрим a и b как полиномы и , результат операции c(u), где коэффициенты в GF(2) прибавляются и умножаются, и берётся остаток отделения c(u) на f(u). Кроме того особенно просто умножить точку a на u. Например, если n = 128,

Также, просто разделить точку a на u, имея ввиду, что а умножается на обратную величину u в поле: . Например,

Основная конструкция семейства ОМАС

Семейство ОМАС определяется блочным шифром Е : KE × , n-битной константой Cst, универсальной хэш-функцией H : × X → , и две уникальных константы , ∈ X, где X является конечной областью функции H. H, и должны удовлетворять следующему условию: (константы являются случайными. Запишем HL(•) для H(L, •).


1. Для любого y ∈ , число L ∈ таково, что HL() = y не более чем для некоторого достаточно малого .
2. Для любого y ∈ , число L ∈ таково, что HL() = y не более чем для некоторого достаточно малого .
3. Для любого y ∈ , число L ∈ таково, что HL() ⊕ HL() = y не более чем для некоторого достаточно малого .
4. Для любого y ∈ , число L ∈ таково, что HL() ⊕L = y не более чем для некоторого достаточно малого .
5. Для любого y ∈ , число L ∈ таково, что HL() ⊕L = y не более чем для некоторого достаточно малого .
6. Для любого y ∈ , число L ∈ таково, что HL() ⊕ HL(Cst2) ⊕ L = y не более чем для некоторого достаточно малого .

Далее приведём пседвдокод, который описывает семейство OMAC.

Algorithm
L ← ;
Y [0] ← ;
Partition M into M[1] ... M[m]
for i ← 1 to m − 1 do
X[i] ← M[i] ⊕ Y [i − 1];
Y [i] ← );
X[m] ← ) ⊕ Y [m − 1];
if |M[m]| = n then X[m] ← X[m] ⊕ ;
else X[m] ← X[m] ⊕ ;
T ← );
return T;

Алгоритм семейства ОМАС проиллюстрирован на Рис.3, где (•) определяется в (1). Пространство ключей К семейства ОМАС: . Оно принимает значения ключа K ∈ и сообщение M ∈ {0, 1}*, и возвращает строку из области .

Предложенная спецификация

В OMAC1 положим Cst = , (x) = L•x, = u и = , где «•» означает умножение в . , и равносильны. OMAC2 аналогичен OMAC1, исключая вместо . , и равносильны. Кроме того, , и могут быть эффективно вычислены с помощью одного сдвига и одной операции XOR от и , соответственно как показано в (2) и (3). Легко заметить, что условия в Sec. 3 выполняются для в OMAC1 и OMAC2. OMAC1 и OMAC2 проиллюстрированы на Рис.2 и описываются следующим образом:
1. Для OMAC1:

Algorithm
L ← ;
Y [0] ← ;
Partition M into M[1] ... M[m]
for i ← 1 to m − 1 do
X[i] ← M[i] ⊕ Y [i − 1];
if |M[m]| = n
then X[m] ← X[m] ⊕ ;
else Y[i] ← E_k(X[i]);
X[m] ← ) ⊕ Y [m − 1];
if |M[m]| = n then X[m] ← X[m] ⊕ ;
else X[m] ← X[m] ⊕ ;
T ← );
return T;


1. Для OMAC2:

Algorithm
L ← ;
Y [0] ← ;
Partition M into M[1] ... M[m]
for i ← 1 to m − 1 do
X[i] ← M[i] ⊕ Y [i − 1];
if |M[m]| = n
then X[m] ← X[m] ⊕ ;
else Y[i] ← E_k(X[i]);
X[m] ← ) ⊕ Y [m − 1];
if |M[m]| = n then X[m] ← X[m] ⊕ ;
else X[m] ← X[m] ⊕ ;
T ← );
return T;

Безопасность семейства OMAC

Определение защищённости

Пусть Perm(n) означает набор всех перестановок из , так же пусть P является случайной перестановкой, если Р — случайная выборка из Perm(n). Безопасность блочного шифра E может быть количественно определена как , максимальное преимущество, которое противник A может получить, когда пытается выделить (со случайно выбранным ключём K) из случайной перестановки P(•), когда допускается вычисление времени t и q запросов (который является либо либо ). Это преимущество определяется следующим образом.

Скажем, что блочный шифр E — защищён, если существенно мало. Аналогично, MAC-алгоритм — F : × , где  — набор ключей, тогда запишем для F(K, •). Скажем, что противник взламывает, если A выдаёт , где A никогда не запрашивает M из . Тогда мы определяем преимущество как

где максимум берётся по всем противникам, кто «работает» не мобее времени t, производит не более q запросов, и кадлый запрос не более μ бит. Будем говорить, MAC алгоритм защищён (безопасен), если величина пренебрежимо мала. Обозначим Rand(∗, n) набор всех функций из {0, 1}* в . Этот набор даётся вероятностной мерой в предположении, что случайный элемент R набора Rand(∗, n) связан или ассоциирован с каждой строкой M ∈ {0, 1}* случайной строки R(M)∈. Далее, мы определим преймущество как

где максимум берётся по всем противникам, кто «работает» время не больше t, делает не более q запросов, и каждый запрос не более μ бит. Тогда можно сказать, что MAC алгоритм псевдослучайный, если величина пренебрежимо мала (viprf устанавливается для Variablelength Input PseudoRandom Function — входные псевдо случайные функции переменной длины). Без ограничения общности, как предполагается, противники никогда не делают запросы вне области , а так же никогда не повторяют запросы.

Далее приведём основные теоремы(их формулировки без доказательств).

Lemma 5.1 (Главная Лемма для семейства ОМАС). Предположим, что H, Cst1 и Cst2 удовлетворяют условиям Sec. 3 для некоторых пренебрежимо малых , а так же пусть Cst — произвольная n-битная константа. Так же предположим, что случайная перестановка P ∈ Perm(n) используется в семействе OMAC(OMAC-family) как базовый блочный шифр. Пусть A — противник, который делает не более q запросов, и каждый запрос не более nm бит. (m — максимальное число блоков в каждом запросе.) Положим m ≤ 2n/4. Тогда

где . Следующие результаты присущи как OMAC1 так и OMAC2. Сначала, мы получили следущую лемму заменой є = 2−n в Lemma 5.1.

Lemma 5.2 (Главная Лемма для семейства ОМАС). Предположим, что случайная перестановка P ∈ Perm(n) используется в OMAC как базовый блочный шифр . Пусть A будет противником, который делает не более q запросов, и каждый запрос не более nm бит. Положим m ≤ 2n/4. Тогда

Далее покажем, что OMAC является псевдослучайным, если базовый блочный шифр Е защищён.

Замечание 5.1. Пусть E : × является базовым блочным шифром, который используется в OMAC. Тогда , где t’ = t + O(mq) and q’ = mq + 1.
В конце покажем, что OMAC защищён как aMAC алгоритм из Замечание 5.1 в обычном смысле. Theorem 5.1. Пусть E : KE × является базовым блочным шифром, используемый в OMAC. Тогда
,
где t’ = t + O(mq) and q’ = mq + 1.

Литература

  • Tetsu Iwata and Kaoru Kurosawa. OMAC: One-Key CBC MAC. — 4–12–1 Nakanarusawa, Hitachi, Ibaraki 316-8511, Japan.: Department of Computer and Information Sciences,Ibaraki University, 2003. — С. 32.