Содержание
Криптогафическая хэш-функция Whirlpool
- Whirlpool
- криптографическая хэш-функция, разработанная Винсентом Риджменом (Vincent Rijmen) и Пауло Баретто (Paolo Barreto). Впервые опубликована в ноябре 2000 года. Осуществляет хэширование входного сообщения с длиной до бит. Ообрена европейской организацией NESSIE (New European Schemes for Signature, Integrity and Encryption - Новые европейские схемы подписей, целостности и шифрования)
Whirlpool использует структуру Меркля-Дамгарда и одностороннюю функцию сжатия Миагучи-Пренеля для формирования 512-блока зашифрованого текста . Поскольку внутренний блок шифрования работает с 512-битными входными сообщениями, то исходное сообщение необходимо разбить на блоки по 512 бит. При этом последний блок, который содержит конец сообщения, может оказаться неполным.
Для решения данной проблемы в Whirlpool используется дополнение входного сообщения. Результатом дополнения сообщения является сообщение , длина которого кратна 512 бит. Пусть — длина исходного сообщения. Для того, чтобы получить , необходимо сделать 3 операции:
- К концу сообщения приписать бит «1» ;
- Приписать x битов «0» так, чтобы длина полученной строки была кратна 256 нечетное число раз;
- Приписать 256-битное представление числа .
Полученная строка разбивается на 512-битовые блоки , , , которые используются для генерации последовательности хэш-значений , , ( - строка из 512 «0» бит). Для вычисления , шифрует , используя в качестве ключа , и выполняет между и . Значением хэш-функции является .
Раунды
Шифр Whirlpool использует 10 раундов. Размер блока и размер ключа - 512 бит. Ключом для раунда является .
Функция раунда
512 бит входного блока группируются в 64 байта . Затем эти байты записываются
в матрицу размером 8 * 8:
В дальнейшем нам придется работать в конечном поле . Элементы это байты, они могут складываться с помощью операции XOR. Модель конечного поля зависит от выбора неприводимого многочлена степени 8. Для Whirlpool этим многочленом является .
Процедуры, входящие в функцию раунда:
1) сдвиг столбцов матрицы состояния на различную величину (ShiftColumns?); 2) перемешивание данных каждого столбца матрицы состояния (SubBytes?); 3) умножение каждой строки матрицы состояния на фиксированный многочлен в (MixRows?); 4) сложение ключа раунда с матрицей состояния (AddRoundKey?).
SubBytes?
Процедура SubBytes? обеспечивает перемешивание данных каждого столбца матрицы состояния. Байт представляют в виде двух шестнадцатеричных цифр. Левая цифра определяет строку, а правая - столбец таблицы подстановки. Две шестнадцатеричных цифры в пересечении строки и столбца определяют новый байт.
В преобразовании SubBytes? матрица состояний обрабатывается как матрица байтов 8 * 8. В процессе каждый байт преобразуется независимо; мы имеем 64 различных преобразования.
Ниже приведена таблица подстановки (S-блок) для преобразования байтов. Например, два байта, и , которые отличаются только одним битом, преобразованы к и $88 sub 16$$, которые отличаются пятью битами.
Таблица может быть вычислена алгебраически, используя поле с неприводимым полиномом . Каждая шестнадцатеричная цифра в байте вводится в миниблок ( и ). Результаты передаются в другой миниблок R. E - блоки вычисляют степень, равную шестнадцатеричному значению входа; R -миниблок использует псевдослучайный генератор чисел.
КатегорияКриптография