AES (стандарт шифрования)

AES, Rijndael-AES, Rijndael
Создатель Винсент Рэймен
Йоан Даймен
Создан 1998 г.
Размер ключа 128/192/256 бит
Размер блока 128 бит
Число раундов 10/12/14 (зависит от размера ключа)
Тип Подстановочно-перестановочная сеть
Логотип Викисклада Медиафайлы на Викискладе

AES (англ. Advanced Encryption Standard; также Rijndael, [rɛindaːl] — рейндал) — симметричный алгоритм блочного шифрования (размер блока 128 бит, ключ 128/192/256 бит), принятый в качестве стандарта шифрования правительством США по результатам конкурса AES. Этот алгоритм хорошо проанализирован и сейчас широко используется, как это было с его предшественником DES. Национальный институт стандартов и технологий США (англ. National Institute of Standards and Technology, NIST) опубликовал спецификацию AES 26 ноября 2001 года после пятилетнего периода, в ходе которого были созданы и оценены 15 кандидатур. 26 мая 2002 года AES был объявлен стандартом шифрования. По состоянию на 2009 год AES является одним из самых распространённых алгоритмов симметричного шифрования[1][2]. Поддержка ускорения AES была введена фирмой Intel в семейство процессоров x86 начиная с Arrandale[англ.] в 2010 году, а затем на процессорах Sandy Bridge; фирмой AMD — в Bulldozer с 2011 года.

История AES

2 января 1997 года NIST объявляет[3] о намерении выбрать преемника для DES, являвшегося американским стандартом с 1977 года. 2 октября 2000 года было объявлено, что победителем конкурса стал алгоритм Rijndael[4], и началась процедура стандартизации. 28 февраля 2001 года был опубликован проект, а 26 ноября 2001 года AES был принят как FIPS 197. Историческую ретроспективу конкурса можно проследить на веб-сайте NIST[5].

Описание AES

Определения и вспомогательные процедуры

Определения
Block последовательность бит, из которых состоит input, output, State и Round Key. Также под Block можно понимать последовательность байтов
Cipher Key секретный криптографический ключ, который используется Key Expansion процедурой, чтобы произвести набор ключей для раундов (Round Keys); может быть представлен как прямоугольный массив байтов, имеющий четыре строки и Nk столбцов
Ciphertext выходные данные алгоритма шифрования
Key Expansion процедура генерации Round Keys из Cipher Key
Round Key Round Keys получаются из Cipher Key использованием процедуры Key Expansion. Они применяются к State при шифровании и расшифровании
State промежуточный результат шифрования, который может быть представлен как прямоугольный массив байтов, имеющий 4 строки и Nb столбцов
S-box нелинейная таблица замен, использующаяся в нескольких трансформациях замены байтов и в процедуре Key Expansion для взаимнооднозначной замены значения байта. Предварительно рассчитанный S-box можно увидеть ниже
Nb число столбцов (32-битных слов), составляющих State. Для AES Nb = 4
Nk число 32-битных слов, составляющих шифроключ. Для AES Nk = 4, 6, или 8
Nr число раундов, которое является функцией Nk и Nb. Для AES Nr = 10, 12, 14
Rcon[] массив, который состоит из битов 32-разрядного слова и является постоянным для данного раунда. Предварительно рассчитанный Rcon[] можно увидеть ниже

S-box


Sbox = array{
        0x63, 0x7c, 0x77, 0x7b, 0xf2, 0x6b, 0x6f, 0xc5, 0x30, 0x01, 0x67, 0x2b, 0xfe, 0xd7, 0xab, 0x76, 
        0xca, 0x82, 0xc9, 0x7d, 0xfa, 0x59, 0x47, 0xf0, 0xad, 0xd4, 0xa2, 0xaf, 0x9c, 0xa4, 0x72, 0xc0, 
        0xb7, 0xfd, 0x93, 0x26, 0x36, 0x3f, 0xf7, 0xcc, 0x34, 0xa5, 0xe5, 0xf1, 0x71, 0xd8, 0x31, 0x15, 
        0x04, 0xc7, 0x23, 0xc3, 0x18, 0x96, 0x05, 0x9a, 0x07, 0x12, 0x80, 0xe2, 0xeb, 0x27, 0xb2, 0x75, 
        0x09, 0x83, 0x2c, 0x1a, 0x1b, 0x6e, 0x5a, 0xa0, 0x52, 0x3b, 0xd6, 0xb3, 0x29, 0xe3, 0x2f, 0x84, 
        0x53, 0xd1, 0x00, 0xed, 0x20, 0xfc, 0xb1, 0x5b, 0x6a, 0xcb, 0xbe, 0x39, 0x4a, 0x4c, 0x58, 0xcf, 
        0xd0, 0xef, 0xaa, 0xfb, 0x43, 0x4d, 0x33, 0x85, 0x45, 0xf9, 0x02, 0x7f, 0x50, 0x3c, 0x9f, 0xa8, 
        0x51, 0xa3, 0x40, 0x8f, 0x92, 0x9d, 0x38, 0xf5, 0xbc, 0xb6, 0xda, 0x21, 0x10, 0xff, 0xf3, 0xd2, 
        0xcd, 0x0c, 0x13, 0xec, 0x5f, 0x97, 0x44, 0x17, 0xc4, 0xa7, 0x7e, 0x3d, 0x64, 0x5d, 0x19, 0x73, 
        0x60, 0x81, 0x4f, 0xdc, 0x22, 0x2a, 0x90, 0x88, 0x46, 0xee, 0xb8, 0x14, 0xde, 0x5e, 0x0b, 0xdb, 
        0xe0, 0x32, 0x3a, 0x0a, 0x49, 0x06, 0x24, 0x5c, 0xc2, 0xd3, 0xac, 0x62, 0x91, 0x95, 0xe4, 0x79, 
        0xe7, 0xc8, 0x37, 0x6d, 0x8d, 0xd5, 0x4e, 0xa9, 0x6c, 0x56, 0xf4, 0xea, 0x65, 0x7a, 0xae, 0x08, 
        0xba, 0x78, 0x25, 0x2e, 0x1c, 0xa6, 0xb4, 0xc6, 0xe8, 0xdd, 0x74, 0x1f, 0x4b, 0xbd, 0x8b, 0x8a, 
        0x70, 0x3e, 0xb5, 0x66, 0x48, 0x03, 0xf6, 0x0e, 0x61, 0x35, 0x57, 0xb9, 0x86, 0xc1, 0x1d, 0x9e, 
        0xe1, 0xf8, 0x98, 0x11, 0x69, 0xd9, 0x8e, 0x94, 0x9b, 0x1e, 0x87, 0xe9, 0xce, 0x55, 0x28, 0xdf, 
        0x8c, 0xa1, 0x89, 0x0d, 0xbf, 0xe6, 0x42, 0x68, 0x41, 0x99, 0x2d, 0x0f, 0xb0, 0x54, 0xbb, 0x16
    };

Обратный S-box для процедуры InvSubBytes

InvSbox = array{
        0x52, 0x09, 0x6a, 0xd5, 0x30, 0x36, 0xa5, 0x38, 0xbf, 0x40, 0xa3, 0x9e, 0x81, 0xf3, 0xd7, 0xfb,
        0x7c, 0xe3, 0x39, 0x82, 0x9b, 0x2f, 0xff, 0x87, 0x34, 0x8e, 0x43, 0x44, 0xc4, 0xde, 0xe9, 0xcb,
        0x54, 0x7b, 0x94, 0x32, 0xa6, 0xc2, 0x23, 0x3d, 0xee, 0x4c, 0x95, 0x0b, 0x42, 0xfa, 0xc3, 0x4e,
        0x08, 0x2e, 0xa1, 0x66, 0x28, 0xd9, 0x24, 0xb2, 0x76, 0x5b, 0xa2, 0x49, 0x6d, 0x8b, 0xd1, 0x25,
        0x72, 0xf8, 0xf6, 0x64, 0x86, 0x68, 0x98, 0x16, 0xd4, 0xa4, 0x5c, 0xcc, 0x5d, 0x65, 0xb6, 0x92,
        0x6c, 0x70, 0x48, 0x50, 0xfd, 0xed, 0xb9, 0xda, 0x5e, 0x15, 0x46, 0x57, 0xa7, 0x8d, 0x9d, 0x84,
        0x90, 0xd8, 0xab, 0x00, 0x8c, 0xbc, 0xd3, 0x0a, 0xf7, 0xe4, 0x58, 0x05, 0xb8, 0xb3, 0x45, 0x06,
        0xd0, 0x2c, 0x1e, 0x8f, 0xca, 0x3f, 0x0f, 0x02, 0xc1, 0xaf, 0xbd, 0x03, 0x01, 0x13, 0x8a, 0x6b,
        0x3a, 0x91, 0x11, 0x41, 0x4f, 0x67, 0xdc, 0xea, 0x97, 0xf2, 0xcf, 0xce, 0xf0, 0xb4, 0xe6, 0x73,
        0x96, 0xac, 0x74, 0x22, 0xe7, 0xad, 0x35, 0x85, 0xe2, 0xf9, 0x37, 0xe8, 0x1c, 0x75, 0xdf, 0x6e,
        0x47, 0xf1, 0x1a, 0x71, 0x1d, 0x29, 0xc5, 0x89, 0x6f, 0xb7, 0x62, 0x0e, 0xaa, 0x18, 0xbe, 0x1b,
        0xfc, 0x56, 0x3e, 0x4b, 0xc6, 0xd2, 0x79, 0x20, 0x9a, 0xdb, 0xc0, 0xfe, 0x78, 0xcd, 0x5a, 0xf4,
        0x1f, 0xdd, 0xa8, 0x33, 0x88, 0x07, 0xc7, 0x31, 0xb1, 0x12, 0x10, 0x59, 0x27, 0x80, 0xec, 0x5f,
        0x60, 0x51, 0x7f, 0xa9, 0x19, 0xb5, 0x4a, 0x0d, 0x2d, 0xe5, 0x7a, 0x9f, 0x93, 0xc9, 0x9c, 0xef,
        0xa0, 0xe0, 0x3b, 0x4d, 0xae, 0x2a, 0xf5, 0xb0, 0xc8, 0xeb, 0xbb, 0x3c, 0x83, 0x53, 0x99, 0x61,
        0x17, 0x2b, 0x04, 0x7e, 0xba, 0x77, 0xd6, 0x26, 0xe1, 0x69, 0x14, 0x63, 0x55, 0x21, 0x0c, 0x7d
        };

Rcon[]


Rcon = array{
        array{0x00, 0x00, 0x00, 0x00},
        array{0x01, 0x00, 0x00, 0x00},
        array{0x02, 0x00, 0x00, 0x00},
        array{0x04, 0x00, 0x00, 0x00},
        array{0x08, 0x00, 0x00, 0x00},
        array{0x10, 0x00, 0x00, 0x00},
        array{0x20, 0x00, 0x00, 0x00},
        array{0x40, 0x00, 0x00, 0x00},
        array{0x80, 0x00, 0x00, 0x00},
        array{0x1b, 0x00, 0x00, 0x00},
        array{0x36, 0x00, 0x00, 0x00}
    };

Вспомогательные процедуры
AddRoundKey() трансформация при шифровании и обратном шифровании, при которой Round Key XOR’ится c State. Длина RoundKey равна размеру State (то есть если Nb = 4, то длина RoundKey равна 128 бит или 16 байт)
InvMixColumns() трансформация при расшифровании, которая является обратной по отношению к MixColumns()
InvShiftRows() трансформация при расшифровании, которая является обратной по отношению к ShiftRows()
InvSubBytes() трансформация при расшифровании, которая является обратной по отношению к SubBytes()
MixColumns() трансформация при шифровании, которая берёт все столбцы State и смешивает их данные (независимо друг от друга), чтобы получить новые столбцы
RotWord() функция, использующаяся в процедуре Key Expansion, которая берёт 4-байтовое слово и производит над ним циклическую перестановку
ShiftRows() трансформации при шифровании, которые обрабатывают State, циклически смещая последние три строки State на разные величины
SubBytes() трансформации при шифровании, которые обрабатывают State, используя нелинейную таблицу замещения байтов (S-box), применяя её независимо к каждому байту State
SubWord() функция, используемая в процедуре Key Expansion, которая берёт на входе четырёхбайтовое слово и, применяя S-box к каждому из четырёх байтов, выдаёт выходное слово

Шифрование

AES является стандартом, основанным на алгоритме Rijndael. Для AES длина input (блока входных данных) и State (состояния) постоянна и равна 128 бит, а длина шифроключа K составляет 128, 192, или 256 бит. При этом исходный алгоритм Rijndael допускает длину ключа и размер блока от 128 до 256 бит с шагом в 32 бита. Для обозначения выбранных длин input, State и Cipher Key в 32-битных словах используется нотация Nb = 4 для input и State, Nk = 4, 6, 8 для Cipher Key соответственно для разных длин ключей.

В начале зашифровывания input копируется в массив State по правилу , для и . После этого к State применяется процедура AddRoundKey(), и затем State проходит через процедуру трансформации (раунд) 10, 12, или 14 раз (в зависимости от длины ключа), при этом надо учесть, что последний раунд несколько отличается от предыдущих. В итоге, после завершения последнего раунда трансформации, State копируется в output по правилу , для и .

Отдельные трансформации SubBytes(), ShiftRows(), MixColumns() и AddRoundKey() — обрабатывают State. Массив w[] — содержит key schedule.


Cipher(byte in[4*Nb], byte out[4*Nb], word w[Nb*(Nr+1)])
begin
    byte state[4,Nb]
    
    state = in

    AddRoundKey(state, w[0, Nb-1])

    for round = 1 step 1 to Nr-1
        SubBytes(state)
        ShiftRows(state)
        MixColumns(state)
        AddRoundKey(state, w[round*Nb, (round+1)*Nb-1])
    end for

    SubBytes(state)
    ShiftRows(state)
    AddRoundKey(state, w[Nr*Nb, (Nr+1)*Nb-1])

    out = state
end

Рис1. Псевдокод для Cipher

SubBytes()

В процедуре SubBytes, каждый байт в state заменяется соответствующим элементом в фиксированной 8-битной таблице поиска, S; bij = S(aij).

Процедура SubBytes() обрабатывает каждый байт состояния, независимо производя нелинейную замену байтов, используя таблицу замен (S-box). Такая операция обеспечивает нелинейность алгоритма шифрования. Построение S-box состоит из двух шагов. Во-первых, производится взятие обратного числа в поле Галуа . Для всех операций в этом поле используется неприводимый полином . Во-вторых, к каждому байту b, из которых состоит S-box, применяется следующая операция:

где , и где есть i-ый бит b, а  — i-ый бит константы . Таким образом обеспечивается защита от атак, основанных на простых алгебраических свойствах.

ShiftRows()

В процедуре ShiftRows байты в каждой строке state циклически сдвигаются влево. Размер смещения байтов каждой строки зависит от её номера

ShiftRows работает со строками State. При этой трансформации строки состояния циклически сдвигаются на r байт по горизонтали в зависимости от номера строки. Для нулевой строки r = 0, для первой строки r = 1 Б и т. д. Таким образом, каждая колонка выходного состояния после применения процедуры ShiftRows состоит из байтов из каждой колонки начального состояния. Для алгоритма Rijndael паттерн смещения строк для 128- и 192-битных строк одинаков. Однако для блока размером 256 бит отличается от предыдущих тем, что 2-е, 3-и и 4-е строки смещаются на 1, 3 и 4 байта соответственно. Это замечание не относится к AES, так как он использует алгоритм Rijndael только с 128-битными блоками, независимо от размера ключа.

MixColumns()

В процедуре MixColumns каждая колонка состояния перемножается с фиксированным многочленом c(x).

В процедуре MixColumns четыре байта каждой колонки State смешиваются, используя для этого обратимую линейную трансформацию. MixColumns обрабатывает состояния по колонкам, трактуя каждую из них как полином третьей степени. Над этими полиномами производится умножение[6] в по модулю на фиксированный многочлен . Вместе с ShiftRows MixColumns вносит диффузию в шифр.

AddRoundKey()

В процедуре AddRoundKey каждый байт состояния объединяется с RoundKey, используя операцию XOR (⊕).

В процедуре AddRoundKey RoundKey каждого раунда объединяется со State. Для каждого раунда Roundkey получается из CipherKey c помощью процедуры KeyExpansion; каждый RoundKey такого же размера, что и State. Процедура производит побитовый XOR каждого байта State с каждым байтом RoundKey.

Алгоритм обработки ключа

Алгоритм обработки ключа состоит из двух процедур:

  • Алгоритм генерации раундовых ключей (алгоритм расширения ключа)
  • Алгоритм выбора раундового ключа (ключа итерации)

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

Алгоритм AES, используя процедуру KeyExpansion() и подавая в неё Cipher Key, K, получает ключи для всех раундов. Всего получается Nb*(Nr + 1) слов: изначально для алгоритма требуется набор из Nb слов, и каждому из Nr раундов требуется Nb ключевых набора данных. Полученный массив ключей для раундов обозначается как , . Алгоритм KeyExpansion() показан в псевдокоде ниже.

Функция SubWord() берёт четырёхбайтовое входное слово и применяет S-box к каждому из четырёх байтов. То, что получилось, подаётся на выход. На вход RotWord() подаётся слово , которое она циклически переставляет и возвращает . Массив слов, постоянный для данного раунда, , содержит значения , где x = {02}, а является степенью в ( начинается с 1).

Из рисунка можно видеть, что первые слов расширенного ключа заполнены Cipher Key. В каждое последующее слово, , кладётся значение, полученное при операции XOR и , те XOR’а предыдущего и на Nk позиций раньше слов. Для слов, позиция которых кратна Nk, перед XOR’ом к w[i-1] применяется трансформация, за которой следует XOR с константой раунда Rcon[i]. Указанная выше трансформация состоит из циклического сдвига байтов в слове (RotWord()), за которой следует процедура SubWord() — то же самое, что и SubBytes(), только входные и выходные данные будут размером в слово.

Важно заметить, что процедура KeyExpansion() для 256-битного Cipher Key немного отличается от тех, которые применяются для 128- и 192- битных шифроключей. Если и кратно , то SubWord() применяется к до XOR’а.

KeyExpansion(byte key[4 * Nk], word w[Nb * (Nr+1)], Nk)
begin
    word temp
    i = 0;
    
    while(i < Nk)
        w[i] = word(key[4*i], key[4*i+1], key[4*i+2], key[4*i+3])
        i = i + 1
    end while
    
    i = Nk

    while(i < Nb * (Nr+1))
        temp = w[i - 1]
        if (i mod Nk = 0)
            temp = SubWord(RotWord(temp)) xor Rcon[i / Nk]
        else if (Nk > 6 and i mod Nk = 4)
            temp = SubWord(temp)
        end if
        w[i] = w[i - Nk] xor temp
        i = i + 1
    end while
end

Псевдокод для Key Expansion

Расшифрование


InvCipher(byte in[4 * Nb], byte out[4 * Nb], word w[Nb * (Nr+1)])
begin
    byte state[4, Nb]
    
    state = in

    AddRoundKey(state, w[Nr * Nb, Nb * (Nr+1) - 1])

    for round = Nr - 1 step -1 downto 1
        InvShiftRows(state)
        InvSubBytes(state)
        AddRoundKey(state, w[Nb * round, Nb * (round+1) - 1])
        InvMixColumns(state)
    end for

    InvShiftRows(state)
    InvSubBytes(state)
    AddRoundKey(state, w[0, Nb - 1])

    out = state
end

Псевдокод для Inverse Cipher

Алгоритм выбора раундового ключа

На каждой итерации раундовый ключ для операции AddRoundKey выбирается из массива ,начиная с элемента до .

Варианты алгоритма

На базе алгоритма Rijndael, лежащего в основе AES, реализованы альтернативные криптоалгоритмы. Среди наиболее известных — участники конкурса Nessie: Anubis на инволюциях, автором которого является Винсент Рэймен и усиленный вариант шифра — Grand Cru Йохана Борста.

Криптостойкость

В июне 2003 года Агентство национальной безопасности США постановило, что шифр AES является достаточно надёжным, чтобы использовать его для защиты сведений, составляющих государственную тайну (англ. classified information). Вплоть до уровня SECRET было разрешено использовать ключи длиной 128 бит, для уровня TOP SECRET требовались ключи длиной 192 и 256 бит[7].

XSL-атака

В отличие от большинства других шифров, AES имеет простое математическое описание. Это беспокоило в том числе и Нильса Фергюсона, который в своей работе отметил, что безопасность шифра основывается на новом непроверенном предположении о сложности решения определённых видов уравнений (англ. «The security of Rijndael depends on a new and untested hardness assumption: it is computationally infeasible to solve equations of this type»)[8][9], а также Брюса Шнайера, который написал в совместной с Нильсом книге:

У нас есть одно критическое замечание к AES: мы не совсем доверяем его безопасности. Что беспокоит нас больше всего в AES, так это его простая алгебраическая структура… Ни один другой блочный шифр не имеет столь простого алгебраического представления. Мы понятия не имеем, ведёт это к атаке или нет, но незнание этого является достаточной причиной, чтобы скептически относиться к использованию AES.

Niels Ferguson, Bruce Schneier Practical Cryptography — 2003 — pp. 56—57

Николя Куртуа (англ. Nicolas Courtois) и Йозеф Пепшик (англ. Josef Pieprzyk) в 2002 году опубликовали статью, в которой описали теоретическую атаку, названную ими XSL-атакой (англ. eXtended Sparse Linearization), которая могла бы позволить вскрыть шифры AES и Serpent[10][11]. Тем не менее, результаты работы не всеми были восприняты оптимистично:

Я считаю, что в работе Куртуа-Пепшика есть ошибка. Они переоценили число линейно-независимых уравнений. В результате у них нет достаточного количества линейных уравнений для решения системы, и [указанный] метод не может взломать Rijndael. Он имеет определённые достоинства и заслуживает изучения, но не взламывает Rijndael в его нынешнем виде.

На странице, посвящённой обсуждению конкурса NESSIE, в конце 2002 года один из авторов шифра, Винсент Рэймен, заявил, что XSL-атака является всего лишь мечтой (англ. The XSL attack is not an attack. It is a dream) (данная точка зрения позже была повторена в 2004 году на 4-й конференции AES в Бонне). На это Куртуа ответил, что данная мечта может стать для автора AES кошмаром (англ. It may also be a very bad dream and turn into a nightmare)[12] (игра слов: dream переводится и как мечта и как сновидение. Nightmare переводится как кошмарный сон, ночной кошмар).

В 2003 году Шон Мёрфи и Мэтт Робшоу (англ. Matt Robshaw) опубликовали работу, в которой (в предположении, что результаты Куртуа и Пепшика верны) обосновали возможность атаки на алгоритм AES, сокращающей количество операций для взлома с 2128 до 2100. Однако на 4-й конференции AES Илья Толи (англ. Ilia Toli) и Альберто Дзанони (англ. Alberto Zanoni) показали, что работа Мёрфи и Робшоу неверна[13]. Позже, в 2007 году, Чу-Ви Лим (англ. Chu-Wee Lim) и Хунгминг Ху (англ. Khoongming Khoo) также показали, что данная атака не может работать в том виде, как она была описана[14].

Атака по сторонним каналам

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

В апреле 2005 года Дэниел Бернштейн (англ. Daniel J. Bernstein) опубликовал работу с описанием атаки, использующей для взлома информацию о времени выполнения каждой операции шифрования[15]. Данная атака потребовала более 200 миллионов выбранных шифротекстов для нахождения ключа[16].

В октябре 2005 года Даг Арне Освик, Ади Шамир и Эран Трумер представили работу с описанием нескольких атак, использующих время выполнения операций для нахождения ключа. Одна из представленных атак получала ключ после 800 операций шифрования. Атака требовала от криптоаналитика возможности запускать программы на той же системе, где выполнялось шифрование[17].

В декабре 2009 года была опубликована работа, в которой использование дифференциального анализа ошибок (англ. Differential Fault Analysis), искусственно создаваемых в матрице состояния на 8-м раунде шифрования, позволило восстановить ключ за 232 операций[18].

Квантовая угроза

Национальный институт стандартов и технологий США (NIST), определяющий национальную политику и стандарты, объявил, что, по его прогнозам, к 2029 г. квантовые компьютеры смогут взломать 128-битное AES-шифрование, которым пользуются многие компании[19].

См. также

Примечания

  1. Лаборатория Чеканова. Intel Core i5 (Clarkdale): анализ аппаратного ускорения шифрования AES. THG (19 января 2010). — «наиболее популярный стандарт симметричного шифрования в мире ИТ». Дата обращения: 14 ноября 2010. Архивировано 26 февраля 2012 года.
  2. Biryukov, Alex and Khovratovich, Dmitry. Related-key Cryptanalysis of the Full AES-192 and AES-256 (англ.) // Advances in Cryptology – ASIACRYPT 2009. — Springer Berlin / Heidelberg, 2009. — Vol. 5912. — P. 1—18. — doi:10.1007/978-3-642-10366-7_1. Архивировано 18 декабря 2010 года.
  3. Архивированная копия. Дата обращения: 7 декабря 2006. Архивировано 6 ноября 2006 года.
  4. NIST Error Page Архивировано 28 сентября 2010 года.
  5. Bounce to index.html Архивировано 17 июля 2014 года.
  6. http://csrc.nist.gov/publications/fips/fips197/fips-197.pdf Архивная копия от 7 апреля 2015 на Wayback Machine «5.1.3 MixColumns() Transformation .. The columns are considered as polynomials over GF(2^8) and multiplied modulo x^4 + 1 with a fixed polynomial a(x), given by a(x) = {03}x³ + {01}x² + {01}x + {02}.»
  7. National Policy on the Use of the Advanced Encryption Standard (AES) to Protect National Security Systems and National Security Information (англ.). Committee on National Security Systems (июнь 2003). Дата обращения: 27 октября 2010. Архивировано 19 февраля 2012 года.
  8. James McLaughlin. The XSL controversy // A survey of block cipher cryptanalysis techniques. — preprint. — York: University of York, 2009. (недоступная ссылка)
  9. Niels Ferguson, Richard Schroeppel, and Doug Whiting. A simple algebraic representation of Rijndael (англ.) // Selected Areas in Cryptography, Proc. SAC 2001, Lecture Notes in Computer Science #2259. — Springer Verlag, 2001. — P. 103—111. Архивировано 16 января 2016 года.
  10. Bruce Schneier. Crypto-Gram Newsletter (англ.). Schneier on Security (15 сентября 2002). Дата обращения: 27 октября 2010. Архивировано 19 февраля 2012 года.
  11. Nicolas Courtois, Josef Pieprzyk. Cryptanalysis of Block Ciphers with Overdefined Systems of Equations (англ.) // Advances in Cryptology — ASIACRYPT 2002 8th International Conference on the Theory Application of Cryptology and Information Security Queenstown, New Zealand, December 1—5, 2002 Proceedings. Lecture Notes in Computer Science (2501). — Springer, 2002. — P. 267—287. — doi:10.1007/3-540-36178-2. Архивировано 26 октября 2020 года.
  12. NESSIE Discussion Forum
  13. Ilia Toli, Alberto Zanoni. An Algebraic Interpretation of AES-128 (англ.) // Proc. of AES Conference. — 2005. — Vol. 2005. — P. 84—97. — doi:10.1007/11506447_8. (недоступная ссылка)
  14. Chu-wee Lim, Khoongming Khoo. An Analysis of XSL Applied to BES (англ.) // Fast Software Encryption. — Heidelberg: Springer Berlin / Heidelberg, 2007. — Vol. 4593. — P. 242—253. — doi:10.1007/978-3-540-74619-5_16. (недоступная ссылка)
  15. Daniel J. Bernstein. Cache-timing attacks on AES (англ.). — 2004. Архивировано 17 сентября 2008 года.
  16. Bruce Schneier. AES Timing Attack (англ.). Schneier on Security (17 мая 2005). Дата обращения: 27 октября 2010. Архивировано 19 февраля 2012 года.
  17. Dag Arne Osvik; Adi Shamir and Eran Tromer. Cache Attacks and Countermeasures: the Case of AES // Topics in Cryptology — CT-RSA 2006, The Cryptographers’ Track at the RSA Conference. — Springer-Verlag, 2005. — P. 1—20. Архивировано 25 ноября 2020 года.
  18. Dhiman Saha, Debdeep Mukhopadhyay, Dipanwita RoyChowdhury. A Diagonal Fault Attack on the Advanced Encryption Standar (англ.) // Cryptology ePrint Archive. — 2009. Архивировано 6 августа 2020 года.
  19. Каку, 2024, с. 20.

Литература

Ссылки

Read other articles:

Pour les articles homonymes, voir BAF. B-1B au sein de la BAF en 2016. La Benefield Anechoic Facility (BAF) est une chambre anéchoïque américaine située au sud-ouest de la base Edwards de la United States Air Force, en Californie. En 2022, il s'agit de la plus grande chambre anéchoïque du monde[1],[2]. La BAF est utilisée pour les programmes de test avionique qui nécessitent un espace important et capable d'absorber les radiofréquences afin de simuler des conditions de champs libre....

 

Canadian cross-country mountain biker (born 1988) Emily BattyBatty in 2013Personal informationBorn (1988-06-16) June 16, 1988 (age 35)Brooklin, Ontario, CanadaHeight1.60 m (5 ft 3 in)[1]Weight48 kg (106 lb)[1]Team informationCurrent teamCanyon MTB Racing TeamDisciplineMountain bikeRoleRiderRider typeCross-countryProfessional teams2010–2011Trek World Racing2011–2020Subaru-Trek2021–Canyon Major winsPanAmGames (2015; 1st place) Medal ...

 

Mammalian protein found in Homo sapiens UTRNAvailable structuresPDBHuman UniProt search: PDBe RCSB List of PDB id codes1BHD, 1QAG,%%s1BHD, 1QAGIdentifiersAliasesUTRN, DMDL, DRP, DRP1, utrophinExternal IDsOMIM: 128240 MGI: 104631 HomoloGene: 21398 GeneCards: UTRN Gene location (Human)Chr.Chromosome 6 (human)[1]Band6q24.2Start144,285,335 bp[1]End144,853,034 bp[1]Gene location (Mouse)Chr.Chromosome 10 (mouse)[2]Band10 A1|10 3.77 cMStart12,257,932 bp[2]...

KamoseIllustration of a votive barque attributed to KamoseFiraunMasa pemerintahanc. 1555–1550 SM[1] (Dinasti ke-17)PendahuluSeqenenre Tao IIPenggantiAhmose IGelar kerajaan Prenomen  (Praenomen) Wadjkheperre[2]</ref> Nomen Kamose[3] Nama Horus Khahernesetef Nama Nebty Wehemmenu Horus emas Sehertawy AnakSitkamose (?)AyahSeqenenre Tao IIIbuAhhotep IMeninggal1550 BC Kamose adalah raja terakhir dinasti ketujuh belas Mesir Thebes. Ia adalah putra dari Seqenenre ...

 

Nama ini menggunakan cara penamaan Spanyol: nama keluarga pertama atau paternalnya adalah Ferrer dan nama keluarga kedua atau maternalnya adalah Ern. David FerrerFerrer di AS Terbuka 2016Kebangsaan SpanyolTempat tinggalValencia, SpanyolLahir2 April 1982 (umur 42)[1]Xàbia, Alicante, SpanyolTinggi1,75 m (5 ft 9 in)Memulai pro2000Pensiun2019Tipe pemainTangan kanan (backhand dua tangan)PelatihJavier Piles (2000–2013)José Francisco Altur (2014)Francisco Fo...

 

For the Dundee, New York radio station that held the call sign WFLR-FM at 95.9 FM from 1968 to 2008, see WFIZ. Radio station in Dundee, New YorkWFLRDundee, New YorkBroadcast areaPenn Yan, New YorkFrequency1570 kHzBranding96.1–96.9–101.9–1570 WFLRProgrammingFormatCountryAffiliationsABC RadioLocal Radio NetworkMotor Racing NetworkOwnershipOwnerFinger Lakes Radio Group, Inc.Sister stationsWAUB, WCGR, WFLK, WGVA, WNYR-FMHistoryCall sign meaningFinger Lakes RadioTechnical information[1&#...

Politics of Portugal Constitution Executive President (list) Marcelo Rebelo de Sousa Prime Minister (list) Luís Montenegro Cabinet Legislature Assembly of the Republic President: Augusto Santos Silva Judiciary Constitutional Court Supreme Court of Justice Court of Auditors Supreme Administrative Court Elections Recent elections Presidential: 201620212026 Legislative:201920222024 Local: 201320172021 European: 201420192024 Political parties Politicians Administrative divisions Districts Auton...

 

أسبوعمعلومات عامةالنوع وحدة زمن — وحدة مشتقة من UCUM لديه أجزاء  القائمة ... الاثنين — الثلاثاء — الأربعاء — الخميس — الجمعة — السبت — الأحد جزء من شهر تستخدم لقياس المدة الزمنية رمز الوحدة u (بالنرويجية بوكمول) تحويلات الوحدةإلى النظام الدولي 604800 ثانية الوحدة القياسية 7 ...

 

Term roughly equivalent to Huna people This article needs additional citations for verification. Please help improve this article by adding citations to reliable sources. Unsourced material may be challenged and removed.Find sources: Iranian Huns – news · newspapers · books · scholar · JSTOR (March 2018) (Learn how and when to remove this message) Bactria and the Hindu Kush The term Iranian Huns is sometimes used for a group of different tribes that li...

منتخب تايلاند لكرة الطائرة للرجال الكنية ลูกยางหนุ่มไทย كونفدرالية الاتحاد الآسيوي لكرة الطائرة مراتب تصنيف فيفب 39 (في أكتوبر 2018) بطولة العالم المشاركات 1 (أولها في سنة 1998) أفضل نتيجة المركز التاسع عشر (1998) كأس العالم الطقم الأساسي الطقم الاحتياطي تعديل مصدري - تعدي...

 

العلاقات الباربادوسية الطاجيكستانية باربادوس طاجيكستان   باربادوس   طاجيكستان تعديل مصدري - تعديل   العلاقات الباربادوسية الطاجيكستانية هي العلاقات الثنائية التي تجمع بين باربادوس وطاجيكستان.[1][2][3][4][5] مقارنة بين البلدين هذه مقارنة عام�...

 

Politics of the Faroe Islands Constitution Constitution Act of Succession Freedom of Speech and the Press Taxation The Crown Monarch King Frederik X Privy Council Purveyors to the Royal Court The unity of the Realm  Kingdom of Denmark  Faroe Islands  Denmark  Greenland ExecutiveRegeringen The Government of Denmark High Commissioner (list) Lene Moyell Johansen Landsstýri The Government of the Faroe Islands Premier Aksel V. Johannesen Deputy Premier Høgni Hoydal Johannesen...

Research center under Nazi Germany For the village and the World War II Luftwaffe airfield that tested the V-1 flying bomb, see Peenemünde and Peenemünde Airfield. Peenemünde Army Research CenterPeenemünde, Germany 1943 RAF photo-recon of Test Stand VII at the Peenemünde Army Research CenterCoordinates54°08′35″N 13°47′38″E / 54.143°N 13.794°E / 54.143; 13.794Site historyBuilt1937In useWorld War IIBattles/warsOperation Crossbow (Bombing of Peenemü...

 

EasySingel oleh Camila Cabellodari album RomanceDirilis11 Oktober 2019DirekamSeptember 2019GenrePop[1]Durasi3:14LabelEpicSycoPenciptaCamila CabelloJustin TranterJohn HillAdam FeeneyLouis BellCarter LangWesten WeissProduserFrank DukesBellLangWeissHillKronologi singel Camila Cabello Cry for Me (2019) Easy (2019) Living Proof (2019) Audio videoEasy di YouTube Easy adalah lagu pop oleh penyanyi asal Kuba-Amerika Serikat, Camila Cabello, dari album studio keduanya Romance (2019). Lagu ini ...

 

Pour les articles homonymes, voir Greber. Cet article est une ébauche concernant un sculpteur français et la numismatique. Vous pouvez partager vos connaissances en l’améliorant (comment ?) selon les recommandations des projets correspondants. Consultez la liste des tâches à accomplir en page de discussion. Henri-Léon GréberNaissance 28 mai 1854BeauvaisDécès 4 juin 1941 (à 87 ans)16e arrondissement de ParisSépulture Cimetière des Batignolles (depuis le 6 juin 1941)Nat...

« Raspoutine » redirige ici. Pour les autres significations, voir Raspoutine (homonymie). Grigori RaspoutineGrigori Raspoutine vers 1916.BiographieNaissance Vers le 9 janvier 1869 (21 janvier dans le calendrier grégorien)Pokrovskoïe (Empire russe)Décès 17 décembre 1916 (30 décembre dans le calendrier grégorien) (47 ans)Pétrograd (Empire russe)Nom de naissance Grigori Efimovitch RaspoutineNationalité RusseActivités Mystique, paysan, homme politique, occultiste, moineConj...

 

Questa voce sull'argomento scrittori italiani è solo un abbozzo. Contribuisci a migliorarla secondo le convenzioni di Wikipedia. Segui i suggerimenti del progetto di riferimento. Silvana Giorgetti Silvana Giorgetti (Roma, 5 luglio 1922 – Roma, 18 giugno 2005) è stata una scrittrice italiana. Indice 1 Biografia 2 Opere 3 Note 4 Bibliografia 5 Collegamenti esterni Biografia Nata e vissuta a Roma, dove è morta il 18 giugno 2005. Frequentò l'Università di Napoli ed esordì nella narr...

 

水の郷百選(みずのさとひゃくせん)は、国土庁(現在の国土交通省)が水環境保全の重要性を広報するため、地域固有の水をめぐる歴史文化や優れた水環境の保全に努め、水を活かした町づくりや村づくりに優れた成果をあげている地域を1996年(平成8年)3月22日に認定したもの。 安曇野:穂高町(蓼川) 水の郷百選一覧 市町村合併のため、所在地名が変更になって...

Mountain in the Sinai Peninsula Jabal Musa redirects here. For other uses, see Jebel Musa (disambiguation). For the biblical Mount Sinai, and a discussion of its possible locations, see Mount Sinai (Bible). For other uses, see Mount Sinai (disambiguation). Mount SinaiEgyptian Arabic: جَبَل مُوسَىٰ, romanized: Gabal MūsāArabic: جَبَل مُوْسَى, romanized: Jabal MūsāCoptic: Ⲡⲧⲟⲟⲩ ⲤⲓⲛⲁClassical Syriac: ܛܘܪܐ ܕܣܝܢܝ Ṭūrāʾ DsynyAnci...

 

Railway station in Somerset, England TemplecombeThe old 1938 signal box and waiting room in December 2015General informationLocationTemplecombe, South SomersetEnglandCoordinates51°00′07″N 2°24′59″W / 51.002°N 2.4164°W / 51.002; -2.4164Grid referenceST707225Managed bySouth Western RailwayPlatforms1Other informationStation codeTMCClassificationDfT category EHistoryOriginal companySalisbury and Yeovil RailwayPre-groupingLondon and South Western RailwayPost-gro...