WikiDer > Дайджест-проверка подлинности доступа

Digest access authentication

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

Технически дайджест-аутентификация - это применение MD5 криптографическое хеширование с использованием nonce ценности для предотвращения повторные атаки. Он использует HTTP протокол.

Обзор

Проверка подлинности дайджест-доступа была изначально указана RFC 2069 (Расширение HTTP: дайджест-проверка подлинности доступа). RFC 2069 определяет примерно традиционную схему дайджест-аутентификации с безопасностью, поддерживаемой сервером значение nonce. Ответ аутентификации формируется следующим образом (где HA1 и HA2 - имена строковых переменных):

HA1 = MD5 (имя пользователя: область: пароль) HA2 = MD5 (метод: digestURI) ответ = MD5 (HA1: nonce: HA2)

Хеш MD5 - это 16-байтовое значение. Значения HA1 и HA2, используемые при вычислении ответа, представляют собой шестнадцатеричное представление (в нижнем регистре) хешей MD5 соответственно.

RFC 2069 позже был заменен на RFC 2617 (HTTP-аутентификация: базовая и дайджест-аутентификация доступа). RFC 2617 введен ряд дополнительных улучшений безопасности для дайджест-аутентификации; «качество защиты» (qop), счетчик одноразового номера, увеличиваемый клиентом, и генерируемый клиентом случайный одноразовый номер. Эти улучшения предназначены для защиты, например, от атака с выбранным открытым текстом криптоанализ.

Если значение директивы алгоритма - "MD5" или не указано, то HA1 будет

HA1 = MD5 (имя пользователя: область: пароль)

Если значение директивы алгоритма "MD5-sess", то HA1 будет

HA1 = MD5 (MD5 (имя пользователя: область: пароль): nonce: cnonce)

Если значение директивы qop - auth или не указано, то HA2 - это

HA2 = MD5 (метод: digestURI)

Если значение директивы qop равно "auth-int", то HA2 будет

HA2 = MD5 (метод: digestURI: MD5 (entityBody))

Если значение директивы qop равно "auth" или "auth-int", вычислите ответ следующим образом:

ответ = MD5 (HA1: nonce: nonceCount: cnonce: qop: HA2)

Если директива qop не указана, вычислите ответ следующим образом:

ответ = MD5 (HA1: nonce: HA2)

Выше показано, что когда qop не указан, более простой RFC 2069 стандарт соблюдается.

В сентябре 2015 г. RFC 7616 заменены RFC 2617 добавив 4 новых алгоритма: «SHA-256», «SHA-256-sess», «SHA-512» и «SHA-512-sess». Кодирование эквивалентно алгоритмам "MD5" и "MD5-sess", с Функция хеширования MD5 заменен на SHA-256 и SHA-512.

Влияние безопасности MD5 на дайджест-аутентификацию

В MD5 расчеты, используемые в дайджест-аутентификации HTTP, предназначены для "в одну сторону", что означает, что будет сложно определить исходный ввод, когда известен только вывод. Однако, если сам пароль слишком прост, то можно проверить все возможные вводы и найти соответствующий вывод ( атака грубой силой) - возможно, с помощью толковый словарь или же подходящий поисковый список, который для MD5 легко доступен.[1]

Схема HTTP была разработана Филипп Халлам-Бейкер в ЦЕРН в 1993 году и не включает в себя последующих улучшений в системах аутентификации, таких как разработка кода аутентификации сообщений хэша с ключом (HMAC). Хотя криптографический используемая конструкция основана на хеш-функции MD5, столкновения атак в 2004 г. считалось, что они не влияют на приложения, для которых неизвестен открытый текст (то есть пароль).[2] Однако претензии в 2006 г.[3] вызывают некоторые сомнения и в отношении других приложений MD5. Однако до сих пор не было показано, что атаки коллизий MD5 представляют угрозу для дайджест-аутентификации.[нужна цитата], а RFC 2617 позволяет серверам реализовать механизмы обнаружения некоторых коллизий и повторные атаки.

Рекомендации по дайджест-аутентификации HTTP

Преимущества

Дайджест-аутентификация HTTP разработана так, чтобы быть более безопасной, чем традиционные схемы дайджест-аутентификации, например "значительно сильнее, чем (например) CRAM-MD5 ..." (RFC 2617).

Некоторые из сильных сторон безопасности дайджест-аутентификации HTTP:

  • Пароль не отправляется на сервер в открытом виде.
  • Пароль не используется непосредственно в дайджесте, а скорее HA1 = MD5 (имя пользователя: область: пароль). Это позволяет некоторые реализации (например, JBoss[4]) для хранения HA1, а не пароля в открытом виде
  • Клиентский одноразовый номер был представлен в RFC 2617, что позволяет клиенту предотвратить атаки с выбранным открытым текстом, Такие как радужные столы которые в противном случае могут угрожать схемам дайджест-аутентификации
  • Одноразовый номер сервера может содержать временные метки. Следовательно, сервер может проверять атрибуты nonce, отправленные клиентами, чтобы предотвратить повторные атаки
  • Серверу также разрешено вести список недавно выданных или использованных одноразовых значений сервера, чтобы предотвратить повторное использование.
  • Это предотвращает Фишинг потому что простой пароль никогда не отправляется ни на один сервер, будь то правильный сервер или нет. (Системы с открытым ключом полагаются на то, что пользователь сможет проверить правильность URL-адреса.)

Недостатки

У аутентификации доступа к дайджесту есть несколько недостатков:

  • Веб-сайт не контролирует пользовательский интерфейс, предоставляемый конечному пользователю.
  • Многие параметры безопасности в RFC 2617 являются необязательными. Если качество защиты (qop) не указано сервером, клиент будет работать в устаревшем режиме с пониженной безопасностью. RFC 2069 Режим
  • Проверка подлинности дайджест-доступа уязвима для Атака "человек посередине" (MITM). Например, злоумышленник MITM может сказать клиентам использовать базовую аутентификацию доступа или устаревший режим дайджест-аутентификации доступа RFC2069. Чтобы расширить это, дайджест-проверка подлинности доступа не предоставляет клиентам механизма проверки подлинности сервера.
  • Некоторые серверы требуют, чтобы пароли хранились с использованием обратимого шифрования. Однако вместо этого можно сохранить усвоенное значение имени пользователя, области и пароля.[5]
  • Это предотвращает использование надежного хэша пароля (например, bcrypt) при сохранении паролей (так как пароль или переваренное имя пользователя, область и пароль должны быть восстановлены)

Кроме того, поскольку Алгоритм MD5 не допускается в FIPS, Дайджест-проверка подлинности HTTP не будет работать с сертифицированными FIPS[примечание 1] крипто модули.

Альтернативные протоколы аутентификации

Безусловно, наиболее распространенным подходом является использование HTTP + HTML-аутентификация на основе форм протокол открытого текста, реже Базовая аутентификация доступа. Эти слабые протоколы открытого текста, используемые вместе с HTTPS сетевое шифрование устраняет многие угрозы, которые дайджест-аутентификация призвана предотвратить. Однако такое использование HTTPS требует от конечного пользователя точной проверки того, что он каждый раз обращается к правильному URL-адресу, чтобы предотвратить отправку своего пароля на ненадежный сервер, что приводит к фишинг Пользователи часто этого не делают, поэтому фишинг стал наиболее распространенной формой нарушения безопасности.

Некоторые из иногда используемых протоколов строгой аутентификации для веб-приложений:

Пример с объяснением

Следующий пример был первоначально приведен в RFC 2617 и расширен здесь, чтобы показать полный текст, ожидаемый для каждого запрос и отклик. Обратите внимание, что распространяется только на качество кода защиты «auth» (аутентификация) - по состоянию на апрель 2005 г., только Опера и Konqueror Известно, что веб-браузеры поддерживают «auth-int» (аутентификация с защитой целостности). Хотя в спецификации упоминается HTTP версии 1.1, схему можно успешно добавить на сервер версии 1.0, как показано здесь.

Эта типичная транзакция состоит из следующих шагов:

  1. Клиент запрашивает страницу, требующую аутентификации, но не предоставляет имя пользователя и пароль.[заметка 2] Обычно это происходит потому, что пользователь просто ввел адрес или перешел по ссылке на страницу.
  2. Сервер отвечает 401 «Несанкционированный» код ответа, предоставляющий область аутентификации и случайно сгенерированное одноразовое значение, называемое nonce.
  3. На этом этапе браузер представит пользователю область аутентификации (обычно это описание компьютера или системы, к которой осуществляется доступ) и запросит имя пользователя и пароль. Пользователь может принять решение об отмене на этом этапе.
  4. После ввода имени пользователя и пароля клиент повторно отправляет тот же запрос, но добавляет заголовок аутентификации, который включает код ответа.
  5. В этом примере сервер принимает аутентификацию, и страница возвращается. Если имя пользователя недействительно и / или пароль неверен, сервер может вернуть код ответа «401», и клиент снова запросит пользователя.

Запрос клиента (без аутентификации)
ПОЛУЧАТЬ /dir/index.html HTTP/1.0Хозяин: localhost

(за которым следует новая линия, в виде возврат каретки за которым следует перевод строки).[6]

Ответ сервера
HTTP/1.0 401 НеавторизованныйСервер: HTTPd / 0.9Дата: Вс, 10 апр 2014 20:26:47 GMTWWW-аутентификация: Digest realm = "[email protected]",                        qop = "auth, auth-int",                        nonce = "dcd98b7102dd2f0e8b11d0f600bfb0c093",                        opaque = "5ccc069c403ebaf9f0171e9517f40e41"Тип содержимого: текст / htmlContent-Length: 153<!DOCTYPE html><html>  <голова>    <мета кодировка=«UTF-8» />    <заглавие>Ошибка</заглавие>  </голова>  <тело>    <h1>401 Неавторизованный.</h1>  </тело></html>
Запрос клиента (логин "Mufasa", пароль "Circle Of Life")
ПОЛУЧАТЬ /dir/index.html HTTP/1.0Хозяин: localhostАвторизация: Digest username = "Муфаса",                     realm = "[email protected]",                     nonce = "dcd98b7102dd2f0e8b11d0f600bfb0c093",                     uri = "/ dir / index.html",                     qop = auth,                     nc = 00000001,                     cnonce = "0a4f113b",                     response = "6629fae49393a05397450978507c4ef1",                     opaque = "5ccc069c403ebaf9f0171e9517f40e41"

(с пустой строкой, как и раньше).

Ответ сервера
HTTP/1.0 200 OkСервер: HTTPd / 0.9Дата: Вс, 10 апр 2005 20:27:03 GMTТип содержимого: текст / htmlContent-Length: 7984

(за которой следует пустая строка и HTML-текст запрещенной страницы).


Значение «отклика» рассчитывается в три этапа, как показано ниже. Когда ценности объединены, они ограниченный двоеточиями.

  1. Вычисляется MD5-хеш объединенного имени пользователя, области аутентификации и пароля. Результат обозначается как HA1.
  2. Хеш MD5 комбинированного метода и дайджеста URI рассчитывается, например из "ПОЛУЧАТЬ" и "/dir/index.html". Результат обозначается как HA2.
  3. Вычисляется MD5-хэш объединенного результата HA1, одноразового номера сервера (nonce), счетчика запросов (nc), одноразового номера клиента (cnonce), качества кода защиты (qop) и результата HA2. Результатом является значение «ответа», предоставленное клиентом.

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

Завершая пример, приведенный в RFC 2617 дает следующие результаты для каждого шага.

   НА1 = MD5 ( "Муфаса: [email protected]: Circle Of Life") = 939e7578ed9e3c518a452acee763bce9 HA2 = MD5 ( "GET: /dir/index.html") = 39aff3a2bab6126f332b942af96d3366 Response = MD5 ( «939e7578ed9e3c518a452acee763bce9:  dcd98b7102dd2f0e8b11d0f600bfb0c093:  00000001: 0a4f113b: auth:  39aff3a2bab6126f332b942af96d3366 ") = 6629fae49393a05397450978507c4ef1

На этом этапе клиент может сделать другой запрос, повторно используя значение одноразового номера сервера (сервер выдает новый одноразовый номер только для каждого Ответ «401»), но с предоставлением нового клиента nonce (cnonce). Для последующих запросов шестнадцатеричный счетчик запросов (nc) должен быть больше последнего использованного значения, иначе злоумышленник может просто "переиграть"старый запрос с теми же учетными данными. Сервер должен убедиться, что счетчик увеличивается для каждого выданного им одноразового значения, соответствующим образом отклоняя любые неверные запросы. Очевидно, что изменение метода, URI и / или значения счетчика приведет к приведет к другому значению ответа.

Сервер должен запоминать значения nonce, которые он недавно сгенерировал. Он также может помнить, когда было выдано каждое значение nonce, истекая их через определенное время. Если используется просроченное значение, сервер должен ответить кодом состояния «401» и добавить устаревший = ИСТИНА в заголовок аутентификации, указывая, что клиент должен повторно отправить с новым предоставленным nonce, не запрашивая у пользователя другое имя пользователя и пароль.

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

Файл .htdigest

.htdigest - это плоский файл используется для хранения имен пользователей, областей и паролей для дайджест-аутентификации HTTP-сервер Apache. Имя файла указано в .htaccess конфигурации и может быть любым, но каноническим именем является ".htdigest". Имя файла начинается с точки, потому что большинство Unix-подобный операционные системы считают любой файл, имя которого начинается с точки, скрытым. Этот файл часто поддерживается ракушка команда "htdigest", которая может добавлять и обновлять пользователей, и правильно кодирует пароль для использования.

Команда "htdigest" находится в apache2-utils пакет на dpkg системы управления пакетами и httpd-инструменты пакет на Управление пакетами RPM системы.

Синтаксис команды htdigest:[7]

htdigest [-c] имя пользователя в области passwdfile

Формат файла .htdigest:[7]

user1: Realm: 5ea41921c65387d904834f8403185412user2: Realm: 734418f1e487083dc153890208b79379

Дайджест-аутентификация SIP

Протокол инициирования сеанса (SIP) использует в основном тот же алгоритм дайджест-аутентификации. Это указано RFC 3261.

Реализация браузера

Большинство браузеров существенно реализовали эту спецификацию, некоторые из них запрещают определенные функции, такие как проверка auth-int или алгоритм MD5-sess. Если сервер требует, чтобы эти дополнительные функции обрабатывались, клиенты могут быть не в состоянии аутентифицироваться (хотя обратите внимание, что mod_auth_digest для Apache не полностью реализует RFC 2617 либо).

Устаревание

Из-за недостатков дайджест-аутентификации по сравнению с базовой аутентификацией через HTTPS она устарела во многих программах, например:

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

Примечания

  1. ^ Ниже приводится список одобренных FIPS алгоритмов: «Приложение A: Утвержденные функции безопасности для FIPS PUB 140-2, Требования безопасности для криптографических модулей» (PDF). Национальный институт стандартов и технологий. 31 января 2014 г.
  2. ^ У клиента может уже быть необходимое имя пользователя и пароль без необходимости запрашивать пользователя, например если они ранее были сохранены в веб-браузере.

Рекомендации

  1. ^ Список радужных таблиц, Project Rainbowcrack. Включает несколько радужных таблиц MD5.
  2. ^ «Hash Collision Q&A». Криптографические исследования. 2005-02-16. Архивировано из оригинал на 06.03.2010.[нужен лучший источник]
  3. ^ Jongsung Kim; Алексей Бирюков; Барт Пренил; Сохи Хонг. «О безопасности HMAC и NMAC на основе HAVAL, MD4, MD5, SHA-0 и SHA-1» (PDF). МАКР.
  4. ^ Скотт Старк (2005-10-08). «DIGEST Authentication (4.0.4+)». JBoss.
  5. ^ «HTTP-аутентификация: базовая аутентификация и дайджест-доступ: сохранение паролей». IETF. Июнь 1999 г.
  6. ^ Тим Бернерс-Ли, Рой Филдинг, Хенрик Фристик Нильсен (1996-02-19). «Протокол передачи гипертекста - HTTP / 1.0: запрос». W3C.CS1 maint: несколько имен: список авторов (связь)
  7. ^ а б "htdigest - управлять пользовательскими файлами для дайджест-аутентификации". apache.org.
  8. ^ Эмануэль Кортей (2002-09-16). «Ошибка 168942 - дайджест-проверка подлинности с защитой целостности». Mozilla.
  9. ^ Тимоти Д. Морган (05.01.2010). «Целостность дайджеста HTTP: еще один взгляд в свете недавних атак» (PDF). vsecurity.com. Архивировано из оригинал (PDF) на 2014-07-14.
  10. ^ «Проверка подлинности дайджеста TechNet». Август 2013.

внешняя ссылка