SHA-2 - SHA-2

[Хеш-алгоритмы]
Концепции
хэш-функции  · SHA  · DSA
Основные стандарты
SHA-0  · SHA-1  · SHA-2  · SHA-3
SHA-2
Общее
ДизайнеровНациональное Агенство Безопасности
Впервые опубликовано2001
Серии(SHA-0 ), SHA-1, SHA-2, SHA-3
СертификацияFIPS ПАБ 180-4, г. CRYPTREC, НЕССИ
Деталь
Размеры дайджеста224, 256, 384 или 512 бит
СтруктураСтроительство Меркле-Дамгарда с участием Функция сжатия Дэвиса-Мейера
Раундов64 или 80
Лучшая публика криптоанализ
Атака 2011 года прерывается сопротивление прообразу для 57 из 80 раундов SHA-512 и 52 из 64 раундов для SHA-256.[1]

Атака псевдо-коллизией до 46 раундов SHA-256.[2]

SHA-256 и SHA-512 склонны к атаки удлинения длины. Угадав скрытую часть состояния, атаки по увеличению длины на SHA-224 и SHA-384 будут успешными с вероятностью 2.−(256−224) = 2−32 > 2−224 и 2−(512−384) = 2−128 > 2−384 соответственно.

SHA-2 (Алгоритм безопасного хеширования 2) представляет собой набор криптографические хеш-функции разработан в США Национальное Агенство Безопасности (NSA) и впервые опубликовано в 2001 году.[3][4] Они построены с использованием Структура Меркла-Дамгарда, из функция одностороннего сжатия сам построен с использованием Структура Дэвиса-Мейера из специализированного блочный шифр.

SHA-2 включает значительные изменения по сравнению с предшественником, SHA-1. Семейство SHA-2 состоит из шести хэш-функций с переваривает (хеш-значения), которые составляют 224, 256, 384 или 512 бит: SHA-224, SHA-256, SHA-384, SHA-512, SHA-512/224, SHA-512/256. SHA-256 и SHA-512 - это новые хэш-функции, вычисляемые с помощью 32-битных и 64-битных слов соответственно. Они используют разные величины сдвига и аддитивные константы, но в остальном их структуры практически идентичны, различаются только количеством раундов. SHA-224 и SHA-384 - это усеченные версии SHA-256 и SHA-512 соответственно, вычисленные с разными начальными значениями. SHA-512/224 и SHA-512/256 также являются усеченными версиями SHA-512, но начальные значения генерируются с использованием метода, описанного в Федеральные стандарты обработки информации (FIPS) ПУБ 180-4.

SHA-2 был впервые опубликован Национальный институт стандартов и технологий (NIST) как федеральный стандарт США (FIPS). Семейство алгоритмов SHA-2 запатентовано в патенте США 6829355.[5] Соединенные Штаты выпустили патент под Безвозмездная лицензия.[6]

В настоящее время лучшие публичные атаки ломаются сопротивление прообразу для 52 из 64 раундов SHA-256 или 57 из 80 раундов SHA-512, и сопротивление столкновению для 46 из 64 раундов SHA-256.[1][2]

Стандарт хеширования

Одна итерация функции сжатия семейства SHA-2. Синие компоненты выполняют следующие операции:
    
    
    
    
Побитовое вращение использует разные константы для SHA-512. Приведены числа для SHA-256.
Красный сложение по модулю 232 для SHA-256 или 264 для SHA-512.

С публикацией FIPS PUB 180-2 NIST добавил три дополнительных хэш-функции в семейство SHA. Все эти алгоритмы известны как SHA-2, названные в честь длины их дайджеста (в битах): SHA-256, SHA-384 и SHA-512.

Алгоритмы были впервые опубликованы в 2001 году в проекте FIPS PUB 180-2, после чего были приняты общественное рассмотрение и комментарии. В августе 2002 года FIPS PUB 180-2 стал новым Стандарт безопасного хеширования, заменяющий FIPS PUB 180-1, выпущенный в апреле 1995 года. Обновленный стандарт включал исходный алгоритм SHA-1 с обновленной технической нотацией, согласующейся с описанием внутренней работы семейства SHA-2.[4]

В феврале 2004 г. было опубликовано уведомление об изменении для FIPS PUB 180-2, в котором указывался дополнительный вариант, SHA-224, определенный для соответствия длине ключа двухключевого Тройной DES.[7] В октябре 2008 года стандарт был обновлен в FIPS PUB 180-3, включая SHA-224 из уведомления об изменении, но в остальном никаких фундаментальных изменений в стандарт не внесено. Основной причиной обновления стандарта было перемещение информации о безопасности хэш-алгоритмов и рекомендаций по их использованию в специальные публикации 800-107 и 800-57.[8][9][10] Подробные тестовые данные и примеры дайджестов сообщений также были удалены из стандарта и представлены в виде отдельных документов.[11]

В январе 2011 года NIST опубликовал SP800-131A, в котором определен переход от действующего на тот момент минимального 80-битного уровня безопасности (обеспечиваемого SHA-1), допустимого для использования федеральным правительством до конца 2013 года, к 112-битному уровню безопасности (предоставляется по SHA-2), являющееся минимальным требованием (начиная с 2014 г.) и рекомендуемым уровень безопасности (начиная с даты публикации в 2011 г.).[12]

В марте 2012 года стандарт был обновлен в FIPS PUB 180-4, добавлены хэш-функции SHA-512/224 и SHA-512/256 и описан метод генерации начальных значений для усеченных версий SHA-512. Кроме того, ограничение на набивка входные данные перед вычислением хэша были удалены, что позволило рассчитывать хеш-данные одновременно с генерацией контента, такого как видео- или аудиоканал в реальном времени. Заполнение последнего блока данных должно происходить до вывода хэша.[13]

В июле 2012 года NIST пересмотрел SP800-57, который предоставляет руководство по управлению криптографическими ключами. Публикация запрещала создание цифровых подписей с хэш-безопасностью ниже 112 бит после 2013 года. В предыдущей редакции 2007 года было указано, что отсечка будет выполняться до конца 2010 года.[10] В августе 2012 года NIST пересмотрел SP800-107 таким же образом.[9]

В Конкурс хеш-функций NIST выбрал новую хеш-функцию, SHA-3, в 2012.[14] Алгоритм SHA-3 не является производным от SHA-2.

Приложения

Хэш-функция SHA-2 реализована в некоторых широко используемых приложениях и протоколах безопасности, включая TLS и SSL, PGP, SSH, S / MIME, и IPsec.

SHA-256 участвует в процессе аутентификации Debian программные пакеты[15] и в DKIM стандарт подписи сообщений; SHA-512 является частью системы аутентификации архивного видео с Международный уголовный трибунал по геноциду в Руанде.[16] SHA-256 и SHA-512 предлагаются для использования в DNSSEC.[17] Поставщики Unix и Linux переходят на использование 256- и 512-битного SHA-2 для безопасного хеширования паролей.[18]

Несколько криптовалюты любить Биткойн использовать SHA-256 для проверки транзакций и расчета доказательство работы[19] или доказательство ставки.[20] Подъем ASIC Чипы ускорителя SHA-2 привели к использованию зашифровать схемы доказательства работы.

SHA-1 и SHA-2 являются Безопасные алгоритмы хеширования требуется по закону для использования в определенных Правительство США приложения, в том числе использование в других криптографических алгоритмах и протоколах, для защиты конфиденциальной несекретной информации. FIPS PUB 180-1 также поощрял принятие и использование SHA-1 частными и коммерческими организациями. SHA-1 выводится из эксплуатации для большинства государственных нужд; Национальный институт стандартов и технологий США сообщает: "Федеральные агентства должен прекратите использование SHA-1 для ... приложений, которым требуется защита от конфликтов, как только это станет практически возможным, и должны использовать семейство хэш-функций SHA-2 для этих приложений после 2010 г. "(курсив в оригинале).[21] Директива NIST о том, что правительственные учреждения США должны прекратить использование SHA-1 после 2010 г.[22] надеялись, что это ускорит переход от SHA-1.

Первоначально функции SHA-2 не были быстро приняты, несмотря на лучшую безопасность, чем SHA-1. Причины могут включать отсутствие поддержки SHA-2 в системах под управлением Windows XP SP2 или более ранней версии.[23] и отсутствие ощущаемой срочности, поскольку коллизии SHA-1 еще не были обнаружены. В Гугл Хром команда объявила о плане постепенного прекращения поддержки их веб-браузером сертификатов TLS, зависящих от SHA-1, в период с конца 2014 по начало 2015 года.[24][25][26] Аналогичным образом Microsoft объявила[27] это Internet Explorer и Край перестанет принимать общедоступные сертификаты TLS, подписанные SHA-1, с февраля 2017 г. Mozilla отключил SHA-1 в начале января 2016 года, но пришлось временно снова включить его с помощью Fire Fox обновление, после проблем с веб-интерфейсом пользователя некоторых моделей маршрутизаторов и приборы безопасности.[28]

Криптоанализ и проверка

Для хеш-функции, для которой L это количество биты в Дайджест сообщения, найти сообщение, соответствующее заданному дайджесту сообщения, всегда можно с помощью грубая сила искать в 2L оценки. Это называется атака на прообраз и может быть или не быть практичным в зависимости от L и конкретная вычислительная среда. Второй критерий, обнаружение двух разных сообщений, которые создают один и тот же дайджест сообщения, известный как столкновение, требуется в среднем всего 2L/2 оценки с использованием атака на день рождения.

Некоторые приложения, использующие криптографические хэши, такие как хранилище паролей, лишь минимально подвержены влиянию столкновение. Создание пароля, который работает для данной учетной записи, требует атаки по прообразу, а также доступа к хешу исходного пароля (обычно в тень file), который может быть тривиальным, а может и нет. Обратное шифрование пароля (например, для получения пароля для попытки взломать учетную запись пользователя в другом месте) из-за атак невозможно. (Однако даже безопасный хэш пароля не может предотвратить атаки методом перебора слабые пароли.)

В случае подписания документа злоумышленник не может просто подделать подпись из существующего документа - злоумышленник должен будет предоставить пару документов, один безобидный и один опасный, и заставить держателя закрытого ключа подписать безобидный документ. Существуют практические обстоятельства, при которых это возможно; до конца 2008 года можно было создавать кованые SSL сертификаты с использованием MD5 столкновение, которое будет принято широко используемыми веб-браузерами.[29]

Повышенный интерес к криптографическому анализу хешей во время соревнований SHA-3 привел к появлению нескольких новых атак на семейство SHA-2, лучшие из которых приведены в таблице ниже. Только атаки на столкновение имеют практическую сложность; ни одна из атак не распространяется на хеш-функцию полного раунда.

В FSE 2012 г., исследователи Sony выступил с презентацией, в которой предлагал расширить атаки псевдоколлизиями до 52 раундов на SHA-256 и 57 раундов на SHA-512, опираясь на биклика атака псевдо-прообразом.[30]

Опубликовано вГодМетод атакиАтакаВариантРаундовСложность
Новые коллизионные атаки против
До 24 шагов SHA-2
[31]
2008ДетерминированныйСтолкновениеSHA-25624/64228.5
SHA-51224/80232.5
Прообразы для ступенчато-уменьшенного SHA-2[32]2009Встреча посерединеПрообразSHA-25642/642251.7
43/642254.9
SHA-51242/802502.3
46/802511.5
Продвинутая встреча посередине
атака на прообраз
[33]
2010Встреча посерединеПрообразSHA-25642/642248.4
SHA-51242/802494.6
Дифференциальная атака высшего порядка
на сокращенном SHA-256
[2]
2011ДифференциальныйПсевдо-коллизияSHA-25646/642178
33/64246
Биклики для прообразов: Атаки на
Skein-512 и семейство SHA-2
[1]
2011BicliqueПрообразSHA-25645/642255.5
SHA-51250/802511.5
Псевдо-прообразSHA-25652/642255
SHA-51257/802511
Улучшение локальных столкновений: новинка
Атаки на уменьшенный SHA-256
[34]
2013ДифференциальныйСтолкновениеSHA-25631/64265.5
Псевдо-коллизияSHA-25638/64237
Эвристика ветвления при дифференциальной коллизии
Поиск с приложениями для SHA-512
[35]
2014Эвристический дифференциалПсевдо-коллизияSHA-51238/80240.5
Анализ SHA-512/224 и SHA-512/256[36]2016ДифференциальныйСтолкновениеSHA-25628/64практичный
SHA-51227/80практичный
Псевдо-коллизияSHA-51239/80практичный

Официальная проверка

Реализация всех утвержденных FIPS функций безопасности может быть официально подтверждена через Программа CMVP, совместно управляемыми Национальный институт стандартов и технологий (NIST) и Организация безопасности связи (CSE). Для неформальной проверки пакет для генерации большого количества тестовых векторов доступен для загрузки на сайте NIST; Однако полученная проверка не заменяет формальную проверку CMVP, которая требуется по закону для определенных приложений.

По состоянию на декабрь 2013 г.существует более 1300 проверенных реализаций SHA-256 и более 900 SHA-512, при этом только 5 из них способны обрабатывать сообщения с длиной в битах, не кратной восьми, при поддержке обоих вариантов.[37]

Тестовые векторы

Хеш-значения пустой строки (т. Е. Входного текста нулевой длины).

SHA224 ("")0x d14a028c2a3a2bc9476102bb288234c415a2b01f828ea62ac5b3e42fSHA256 ("")0x e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855SHA384 ("")0x 38b060a751ac96384cd9327eb1b1e36a21fdb71114be07434c0cc7bf63f6e1da274edebfe76f65fbd51ad2f14898b95bSHA512 ("")0x cf83e1357eefb8bdf1542850d66d8007d620e4050b5715dc83f4a921d36ce9ce47d0d13c5d85f2b0ff8318d2877eec2f63b931bd47417a81a538327af927da3eSHA512 / 224 ("")0x 6ed0dd02806fa89e25de060c19d3ac86cabb87d6a0ddd05c333b84f4SHA512 / 256 ("")0x c672b8d1ef56ed28ab87c3622c5114069bdd3ad7b8f9737498d0c01ecef0967a

Даже небольшое изменение в сообщении (с огромной вероятностью) приведет к в основном другому хешу из-за лавинный эффект. Например, добавление точки в конец следующего предложения изменяет почти половину (111 из 224) бит в хеш-коде:

SHA224 ("Быстрая коричневая лиса прыгает через ленивую собаку ")0x 730e109bd7a8a32b1cb9d9a09aa2325d2430587ddbc0c38bad911525SHA224 ("Быстрая коричневая лиса прыгает через ленивую собаку.")0x 619cba8e8e05826e9b8c519c0a5c68f4fb653e8a3d8aa04bb2c8cd4c

Псевдокод

Псевдокод для алгоритма SHA-256 следует. Обратите внимание на значительное увеличение смешивания между битами w [16..63] слова по сравнению с SHA-1.

Примечание 1. Все переменные представляют собой 32-битные целые числа без знака, а сложение вычисляется по модулю 2.32Примечание 2: для каждого раунда существует одна константа раунда k [i] и одна запись в массиве расписания сообщений w [i], 0 ≤ i ≤ 63.Примечание 3: функция сжатия использует 8 рабочих переменных, от a до hПримечание 4: при выражении констант в этом псевдокоде используется правило обратного порядка байтов,    и при разборе данных блока сообщений от байтов до слов, например,    первое слово входного сообщения «abc» после заполнения - 0x61626380Инициализировать хеш-значения:(первые 32 бита дробные части из квадратных корней первых 8 простых чисел 2..19):h0: = 0x6a09e667h1: = 0xbb67ae85h2: = 0x3c6ef372h3: = 0xa54ff53ah4: = 0x510e527fh5: = 0x9b05688ch6: = 0x1f83d9abh7: = 0x5be0cd19Инициализировать массив круглых констант:(первые 32 бита дробные части кубических корней первых 64 простых чисел 2..311):к [0..63]: = 0x428a2f98, 0x71374491, 0xb5c0fbcf, 0xe9b5dba5, 0x3956c25b, 0x59f111f1, 0x923f82a4, 0xab1c5ed5, 0xd807aa98, 0x12835b01, 0x243185be, 0x550c7dc3, 0x72be5d74, 0x80deb1fe, 0x9bdc06a7, 0xc19bf174, 0xe49b69c1, 0xefbe4786, 0x0fc19dc6, 0x240ca1cc, 0x2de92c6f , 0x4a7484aa, 0x5cb0a9dc, 0x76f988da, 0x983e5152, 0xa831c66d, 0xb00327c8, 0xbf597fc7, 0xc6e00bf3, 0xd5a79147, 0x06ca6351, 0x14292967, 0x27b70a85, 0x2e1b2138, 0x4d2c6dfc, 0x53380d13, 0x650a7354, 0x766a0abb, 0x81c2c92e, 0x92722c85, 0xa2bfe8a1, 0xa81a664b, 0xc24b8b70, 0xc76c51a3, 0xd192e819, 0xd6990624 , 0xf40e3585, 0x106aa070, 0x19a4c116, 0x1e376c08, 0x2748774c, 0x34b0bcb5, 0x391c0cb3, 0x4ed8aa4a, 0x5b9cca4f, 0x682e6ff3, 0x748f82ee, 0x78a5636f, 0x84c87814, 0x8cc70208, 0x90befffa, 0xa4506ceb, 0xbef9a3f7, 0xc67178f2Предварительная обработка (Padding):начать с исходного сообщения длиной L бит, добавить один бит '1' добавить K '0 битов, где K - минимальное число> = 0, так что L + 1 + K + 64 кратно 512 добавить L как 64-битное целое число с прямым порядком байтов, что делает общую длину постобработки кратной 512 битОбработайте сообщение последовательными 512-битными блоками:разбить сообщение на 512-битные кускидля каждый блок создает массив расписания сообщений с 64 записями w [0..63] из 32-битных слов (Начальные значения в w [0..63] не имеют значения, поэтому многие реализации обнуляют их здесь)    скопировать блок в первые 16 слов w [0..15] массива расписания сообщений Расширьте первые 16 слов до оставшихся 48 слов w [16..63] массива расписания сообщений:    для я от От 16 до 63 s0: = (w [i-15] вращать вправо  7) xor (w [i-15] вращать вправо 18) xor (w [i-15] сдвиг вправо  3) s1: = (w [i- 2] вращать вправо 17) xor (w [i- 2] вращать вправо 19) xor (w [i- 2] сдвиг вправо 10) w [i]: = w [i-16] + s0 + w [i-7] + s1 Инициализировать рабочие переменные текущим значением хеш-функции:    a: = h0 b: = h1 c: = h2 d: = h3 e: = h4 f: = h5 g: = h6 h: = h7 Основной цикл функции сжатия:    для я от От 0 до 63 S1: = (e вращать вправо 6) xorвращать вправо 11) xorвращать вправо 25) ch: = (e и е) xor ((не д) и g) temp1: = h + S1 + ch + k [я] + w [i] S0: = (a вращать вправо 2) xorвращать вправо 13) xorвращать вправо 22) maj: = (a и б) xorи в) xorи в) temp2: = S0 + maj h: = g g: = f f: = e e: = d + temp1 d: = c c: = b b: = a a: = temp1 + temp2 Добавьте сжатый кусок к текущему хеш-значению:    h0: = h0 + а h1: = h1 + б h2: = h2 + c h3: = h3 + d h4: = h4 + e h5: = h5 + f h6: = h6 + g h7: = h7 + часПроизвести окончательное значение хеш-функции (с прямым порядком байтов):дайджест: = хэш: = h0 добавить h1 добавить h2 добавить h3 добавить h4 добавить h5 добавить h6 добавить h7

Расчет ch и майор значения могут быть оптимизированы таким же образом как описано для SHA-1.

SHA-224 идентичен SHA-256, за исключением того, что:

  • начальные хеш-значения h0 через h7 разные, и
  • вывод создается путем исключения h7.
Начальные хеш-значения SHA-224 (с прямым порядком байтов):(Вторые 32 бита дробных частей квадратных корней от 9-го до 16-го простых чисел 23..53)h [0..7]: = 0xc1059ed8, 0x367cd507, 0x3070dd17, 0xf70e5939, 0xffc00b31, 0x68581511, 0x64f98fa7, 0xbefa4fa4

SHA-512 идентичен по структуре SHA-256, но:

  • сообщение разбито на 1024-битные блоки,
  • начальные хеш-значения и круглые константы расширены до 64 бит,
  • вместо 64 патронов 80,
  • массив расписания сообщений w имеет 80 64-битных слов вместо 64 32-битных слов,
  • чтобы расширить массив расписания сообщений w, цикл от 16 до 79 вместо от 16 до 63,
  • округленные константы основаны на первых 80 простых числах 2..409,
  • размер слова, используемый для вычислений, составляет 64 бита,
  • добавленная длина сообщения (до предварительной обработки) в биты, является 128-битным целым числом с прямым порядком байтов, и
  • используемые величины сдвига и поворота различаются.
Начальные хеш-значения SHA-512 (с прямым порядком байтов):h [0..7]: = 0x6a09e667f3bcc908, 0xbb67ae8584caa73b, 0x3c6ef372fe94f82b, 0xa54ff53a5f1d36f1, 0x510e527fade682d1, 0x9b05688c2b3ecf2d1d1, 0x9b05688c2b3ecf173d9d9d9d9d05d7d5d7d7d9d9d9d1fd9d9d9d9d08d7d6d6d9d9Круглые константы SHA-512:к [0..79]: = [0x428a2f98d728ae22, 0x7137449123ef65cd, 0xb5c0fbcfec4d3b2f, 0xe9b5dba58189dbbc, 0x3956c25bf348b538, 0x59f111f1b605d019, 0x923f82a4af194f9b, 0xab1c5ed5da6d8118, 0xd807aa98a3030242, 0x12835b0145706fbe, 0x243185be4ee4b28c, 0x550c7dc3d5ffb4e2, 0x72be5d74f27b896f, 0x80deb1fe3b1696b1, 0x9bdc06a725c71235, 0xc19bf174cf692694, 0xe49b69c19ef14ad2, 0xefbe4786384f25e3, 0x0fc19dc68b8cd5b5, 0x240ca1cc77ac9c65, 0x2de92c6f592b0275, 0x4a7484aa6ea6e483, 0x5cb0a9dcbd41fbd4, 0x76f988da831153b5, 0x983e5152ee66dfab, 0xa831c66d2db43210, 0xb00327c898fb213f, 0xbf597fc7beef0ee4, 0xc6e00bf33da88fc2, 0xd5a79147930aa725, 0x06ca6351e003826f, 0x142929670a0e6e70, 0x27b70a8546d22ffc, 0x2e1b21385c26c926, 0x4d2c6dfc5ac42aed, 0x53380d139d95b3df, 0x650a73548baf63de, 0x766a0abb3c77b2a8, 0x81c2c92e47edaee6, 0x92722c851482353b, 0xa2bfe8a14cf10364, 0xa81a664bbc423001, 0xc24b8b70d0f89791, 0xc76c51a30654 BE30, 0xd192e819d6ef5218, 0xd69906245565a910, 0xf40e35855771202a, 0x106aa07032bbd1b8, 0x19a4c116b8d2d0c8, 0x1e376c085141ab53, 0x2748774cdf8eeb99, 0x34b0bcb5e19b48a8, 0x391c0cb3c5c95a63, 0x4ed8aa4ae3418acb, 0x5b9cca4f7763e373, 0x682e6ff3d6b2b8a3, 0x748f82ee5defb2fc, 0x78a5636f43172f60, 0x84c87814a1f0ab72, 0x8cc702081a6439ec, 0x90befffa23631e28, 0xa4506cebde82bde9, 0xbef9a3f7b2c67915, 0xc67178f2e372532b, 0xca273eceea26619c, 0xd186b8c721c0c207, 0xeada7dd6cde0eb1e, 0xf57d4f7fee6ed178, 0x06f067aa72176fba, 0x0a637dc5a2c898a6, 0x113f9804bef90dae, 0x1b710b35131c471b, 0x28db77f523047d84, 0x32caab7b40c72493, 0x3c9ebe0a15c9bebc, 0x431d67c49c100d4c, 0x4cc5d4becb3e42b6, 0x597f299cfc657e2a, 0x5fcb6fab3ad6faec, 0x6c44198c4a475817]Сумма и сигма SHA-512:S0: = (a вращать вправо 28) xorвращать вправо 34) xorвращать вправо 39) S1: = (e вращать вправо 14) xorвращать вправо 18) xorвращать вправо 41)s0: = (w [i-15] вращать вправо 1) xor (w [i-15] вращать вправо 8) xor (w [i-15] сдвиг вправо 7) s1: = (w [i-2] вращать вправо 19) xor (w [i-2] вращать вправо 61) xor (w [i-2] сдвиг вправо 6)

SHA-384 идентичен SHA-512, за исключением того, что:

  • начальные хеш-значения h0 через h7 разные (взяты с 9-го по 16-е простые числа), и
  • вывод создается путем исключения h6 и h7.
Начальные хеш-значения SHA-384 (с прямым порядком байтов):h [0..7]: = 0xcbbb9d5dc1059ed8, 0x629a292a367cd507, 0x9159015a3070dd17, 0x152fecd8f70e5939, 0x67332667ffc00b31, 0x8eb44a87685815fc, 0x8fafa8fa8fa4e4fa8fa4e4fa8fa4e4fa8fa4e4fa8fa4e4fa8fa5

SHA-512 / t идентичен SHA-512, за исключением того, что:

  • начальные хеш-значения h0 через h7 даны Функция генерации SHA-512 / t IV,
  • вывод создается путем усечения конкатенации h0 через h7 в т биты
  • т равное 384 не допускается, вместо этого следует использовать SHA-384, как указано, и
  • т значения 224 и 256 особо отмечены как утвержденные.

В Функция генерации SHA-512 / t IV оценивает модифицированный SHA-512 в строке ASCII "SHA-512 /т", замененный десятичным представлением т. В модифицированный SHA-512 то же самое, что и SHA-512, за исключением начальных значений h0 через h7 каждый был XORed с шестнадцатеричной константой 0xa5a5a5a5a5a5a5a5.

Пример реализации C для семейства хэш-функций SHA-2 можно найти в RFC 6234.

Сравнение функций SHA

В таблице ниже внутреннее состояние означает «внутреннюю хеш-сумму» после каждого сжатия блока данных.

Сравнение функций SHA
Алгоритм и вариантРазмер вывода
(биты)
Размер внутреннего состояния
(биты)
Размер блока
(биты)
РаундовОперацииБезопасность (в биты) против столкновения атакВместимость
против атаки удлинения длины
Производительность на Skylake (медиана cpb )[38]Впервые опубликовано
длинные сообщения8 байт
MD5 (в качестве ссылки)128128
(4 × 32)
51264И, Xor, Rot, Добавить (мод 232), Или≤18
(обнаружены коллизии)[39]
04.9955.001992
SHA-0160160
(5 × 32)
51280И, Xor, Rot, Добавить (мод 232), Или<34
(обнаружены коллизии)
0≈ SHA-1≈ SHA-11993
SHA-1<63
(обнаружены коллизии)[40]
3.4752.001995
SHA-2SHA-224
SHA-256
224
256
256
(8 × 32)
51264И, Xor, Rot, Добавить (мод 232), Или, Shr112
128
32
0
7.62
7.63
84.50
85.25
2004
2001
SHA-384
SHA-512
384
512
512
(8 × 64)
102480И, Xor, Rot, Добавить (мод 264), Или, Shr192
256
128 (≤ 384)
0[41]
5.12
5.06
135.75
135.50
2001
SHA-512/224
SHA-512/256
224
256
112
128
288
256
≈ SHA-384≈ SHA-3842012
SHA-3SHA3-224
SHA3-256
SHA3-384
SHA3-512
224
256
384
512
1600
(5 × 5 × 64)
1152
1088
832
576
24[42]И, Xor, Rot, Not112
128
192
256
448
512
768
1024
8.12
8.59
11.06
15.88
154.25
155.50
164.00
164.00
2015
Встряхивание128
Встряхивание256
d (произвольно)
d (произвольно)
1344
1088
мин (d/2, 128)
мин (d/2, 256)
256
512
7.08
8.59
155.25
155.50

В столбце поразрядных операций "Rot" означает вращать не переносить, а "Shr" означает логический сдвиг вправо. Все эти алгоритмы используют модульное дополнение каким-то образом, кроме SHA-3.

Более подробные измерения производительности на современных архитектурах процессоров приведены в таблице ниже.

Архитектура процессораЧастотаАлгоритмРазмер слова (бит)Циклов / байт x86МиБ / с x86Циклов / байт x86-64МиБ / с x86-64
Intel Ivy Bridge3,5 ГГцSHA-2563216.8019913.05256
SHA-5126443.66768.48394
AMD Piledriver ВСУ3,8 ГГцSHA-2563222.8715818.47196
SHA-5126488.364112.43292

Номера производительности с пометкой «x86» выполнялись с использованием 32-битного кода на 64-битных процессорах, тогда как номера «x86-64» - это собственный 64-битный код. Хотя SHA-256 предназначен для 32-битных вычислений, он действительно выигрывает от кода, оптимизированного для 64-битных процессоров на архитектуре x86. 32-битные реализации SHA-512 значительно медленнее своих 64-битных аналогов. Варианты обоих алгоритмов с разными размерами вывода будут работать одинаково, поскольку функции раскрытия и сжатия сообщений идентичны, и отличаются только начальные значения хеш-функции и размеры вывода. Лучшие реализации MD5 и SHA-1 на современных процессорах выполняют от 4,5 до 6 циклов на байт.

Тестирование проводилось Иллинойский университет в Чикаго на их системе Hydra8, работающей на Intel Xeon E3-1275 V2 с тактовой частотой 3,5 ГГц, и на их системе Hydra9, использующей APU AMD A10-5800K с тактовой частотой 3,8 ГГц.[43] Указанные выше скорости циклов на байт представляют собой медианную производительность алгоритма, обрабатывающего сообщение размером 4096 байт с использованием программного обеспечения для криптографического тестирования SUPERCOP.[44] Производительность в МиБ / с экстраполируется из тактовой частоты процессора на одном ядре; реальная производительность будет зависеть от множества факторов.

Реализации

Ниже приведен список библиотек криптографии, поддерживающих SHA-2:

Аппаратное ускорение обеспечивается следующими расширениями процессора:

Смотрите также

использованная литература

  1. ^ а б c Дмитрий Ховратович, Кристиан Рехбергер и Александра Савельева (2011). «Bicliques для прообразов: атаки на Skein-512 и семейство SHA-2» (PDF). IACR Cryptology ePrint Archive. 2011:286.
  2. ^ а б c Марио Ламбергер и Флориан Мендель (2011). «Дифференциальная атака высшего порядка на сокращенный SHA-256» (PDF). Архив ePrint IACR Cryptology. 2011:37.
  3. ^ «О семействе алгоритмов безопасного хеширования» (PDF). Архивировано из оригинал (PDF) на 30.03.2016.
  4. ^ а б Уведомление Федерального реестра 02-21599, Объявление об утверждении публикации FIPS 180-2
  5. ^ США 6829355 
  6. ^ «Лицензионная декларация на патент США 6829355». Получено 2008-02-17. Цитировать журнал требует | журнал = (Помогите)
  7. ^ «FIPS 180-2 с уведомлением об изменении 1» (PDF). csrc.nist.gov.
  8. ^ Уведомление Федерального реестра E8-24743, Объявление об утверждении публикации FIPS 180-3
  9. ^ а б FIPS SP 800-107 Рекомендации для приложений, использующих одобренные алгоритмы хеширования
  10. ^ а б FIPS SP 800-57 Рекомендация по управлению ключами: Часть 1: Общие
  11. ^ «NIST.gov - Отдел компьютерной безопасности - Ресурсный центр по компьютерной безопасности».
  12. ^ FIPS SP 800-131A Рекомендация по переходу на использование криптографических алгоритмов и длин ключей
  13. ^ Уведомление Федерального реестра 2012-5400, Объявление об утверждении публикации FIPS 180-4
  14. ^ «NIST выбирает победителя конкурса алгоритмов безопасного хеширования (SHA-3)». Получено 24 февраля 2015.
  15. ^ «Кодовая база Debian в Google Code». Архивировано из оригинал 7 ноября 2011 г.. Получено 2011-11-08.
  16. ^ Джон Марков, Инструмент для проверки цифровых записей даже при смене технологий, Газета "Нью-Йорк Таймс, 26 января 2009 г.
  17. ^ RFC 5702,RFC-Editor.org
  18. ^ Ульрих Дреппер, Шифрование Unix с SHA-256/512
  19. ^ Биткойн, Излишки. «Биткойн не тратит энергию впустую». Излишек биткойнов. Получено 2020-04-20.
  20. ^ «Что такое SHA-256 и как он связан с биткойнами? - Mycryptopedia». Микриптопедия. 2017-09-21. Получено 2018-09-17.
  21. ^ Ресурсный центр по компьютерной безопасности Национального института стандартов и технологий, Политика NIST в отношении хэш-функций В архиве 2011-06-09 на Wayback Machine, по состоянию на 29 марта 2009 г.
  22. ^ «Безопасное хеширование». NIST. Архивировано из оригинал на 2011-06-25. Получено 2010-11-25.
  23. ^ «Обзор Windows XP с пакетом обновления 3» (PDF). Корпорация Майкрософт. Архивировано из оригинал (PDF) 30 мая 2008 г.
  24. ^ Блог Chromium, 5 сентября 2014 г., Постепенно закрывающийся SHA-1
  25. ^ Эрик Милль. "ШАААААААААААА". SHAAAAAAAAAAAAA.com.
  26. ^ Филиппо Валсорда, Неофициальный FAQ по устареванию Chrome SHA1
  27. ^ «Обновление нашего плана по прекращению поддержки SHA-1 - Блог разработчиков Microsoft EdgeБлог разработчиков Microsoft Edge». blogs.windows.com. Получено 2016-11-28.
  28. ^ Фабиан А. Шершель, HeiseSecurity: Firefox: Mozilla использует SHA-1 и ... и прямо (Немецкий)
  29. ^ Александр Сотиров, Марк Стивенс, Якоб Аппельбаум, Арьен Ленстра, Дэвид Мольнар, Даг Арне Освик, Бенне де Вегер, MD5 сегодня считается опасным: создание поддельного сертификата CA, по состоянию на 29 марта 2009 г.
  30. ^ Джи Ли, Таканори Исобе и Кёдзи Шибутани, Китайская исследовательская лаборатория Sony и Sony Corporation, Преобразование атаки с прообразом встречи-посередине в атаку с псевдоколлизией: применение к SHA-2
  31. ^ Сомитра Кумар Санадхья и Палаш Саркар (2008). «Новые коллизионные атаки против 24-шагового SHA-2» (PDF). IACR Cryptology ePrint Archive. 2008:270.
  32. ^ Казумаро Аоки; Цзянь Го; Кристиан Матусевич; Ю Сасаки и Лей Ван (2009). Прообразы для ступенчато-уменьшенного SHA-2. Достижения в криптологии - ASIACRYPT 2009. Конспект лекций по информатике. 5912. Springer Berlin Heidelberg. С. 578–597. Дои:10.1007/978-3-642-10366-7_34. ISBN  978-3-642-10366-7. ISSN  0302-9743.
  33. ^ Цзянь Го; Сан Линг; Кристиан Рехбергер и Хуаксионг Ван (2010). Усовершенствованные атаки с использованием прообраза "встреча посередине": первые результаты на полном Tiger и улучшенные результаты на MD4 и SHA-2 (PDF). Достижения в криптологии - ASIACRYPT 2010. Конспект лекций по информатике. 6477. Springer Berlin Heidelberg. С. 56–75. Дои:10.1007/978-3-642-17373-8_4. ISBN  978-3-642-17373-8. ISSN  0302-9743.
  34. ^ Флориан Мендель; Томислав Над; Мартин Шлеффер (2013). Улучшение локальных коллизий: новые атаки на сокращенный SHA-256. Достижения в криптологии - EUROCRYPT 2013. Конспект лекций по информатике. 7881. Springer Berlin Heidelberg. С. 262–278. Дои:10.1007/978-3-642-38348-9_16. ISBN  978-3-642-38348-9. ISSN  0302-9743.
  35. ^ Мария Эйхлседер, Флориан Мендель и Мартин Шлеффер (2014). "Ветвящаяся эвристика в дифференциальном поиске коллизий с приложениями к SHA-512" (PDF). Архив ePrint IACR Cryptology. 2014:302.
  36. ^ Кристоф Добрауниг; Мария Эйхлседер и Флориан Мендель (2016). «Анализ SHA-512/224 и SHA-512/256» (PDF). Цитировать журнал требует | журнал = (Помогите)
  37. ^ «Список валидации SHS». NIST. 2017-06-16. Архивировано из оригинал на 2017-06-17.
  38. ^ «Таблица измерений». bench.cr.yp.to.
  39. ^ Тао, Се; Лю, Фаньбао; Фэн, Дэнго (2013). Быстрая атака коллизией на MD5 (PDF). Криптология ePrint Archive (Технический отчет). МАКР.
  40. ^ Стивенс, Марк; Бурштейн, Эли; Карпман, Пьер; Альбертини, Анж; Марков, Ярик. Первая коллизия для полного SHA-1 (PDF) (Технический отчет). Google Research. Сложить резюмеБлог по безопасности Google (23 февраля 2017 г.).
  41. ^ Без усечения известно полное внутреннее состояние хэш-функции, независимо от сопротивления столкновениям. Если вывод усечен, удаленная часть состояния должна быть отыскана и найдена до того, как хэш-функция может быть возобновлена, что позволит продолжить атаку.
  42. ^ «Семейство функций губки Keccak». Получено 2016-01-27.
  43. ^ Контрольные показатели SUPERCOP Измерения хэш-функций, индексированных машиной
  44. ^ «СУПЕРКОП». Получено 24 февраля 2015.
  45. ^ Поддерживаемые наборы шифров SSL / TLS
  46. ^ Журнал изменений Mbed TLS, 7 июля 2007 г.
  47. ^ "Расширение криптографии для процессора ARM Cortex-A53 MPCore. Техническое руководство".

дальнейшее чтение

внешние ссылки