DASS (протокол)
[math]\displaystyle{ A }[/math] | Идентификаторы Алисы (Alice), инициатора сессии |
[math]\displaystyle{ B }[/math] | Идентификатор Боба (Bob), стороны, с которой устанавливается сессия |
[math]\displaystyle{ T }[/math] | Идентификатор Трента (Trent), доверенной промежуточной стороны |
[math]\displaystyle{ K_A, K_B, K_T }[/math] | Открытые ключи Алисы, Боба и Трента |
[math]\displaystyle{ K_A^{-1}, K_B^{-1}, K_T^{-1} }[/math] | Секретные ключи Алисы, Боба и Трента |
[math]\displaystyle{ E_A, \left\{...\right\}_{K_A} }[/math] | Шифрование данных ключом Алисы, либо совместным ключом Алисы и Трента |
[math]\displaystyle{ E_B, \left\{...\right\}_{K_B} }[/math] | Шифрование данных ключом Боба, либо совместным ключом Боба и Трента |
[math]\displaystyle{ \left\{...\right\}_{K_B^{-1}}, \left\{...\right\}_{K_A^{-1}} }[/math] | Шифрование данных секретными ключами Алисы, Боба (цифровая подпись) |
[math]\displaystyle{ I }[/math] | Порядковый номер сессии (для предотвращения атаки с повтором) |
[math]\displaystyle{ K }[/math] | Случайный сеансовый ключ, который будет использоваться для симметричного шифрования данных |
[math]\displaystyle{ E_K, \left\{...\right\}_{K} }[/math] | Шифрование данных временным сеансовым ключом |
[math]\displaystyle{ T_A, T_B }[/math] | Метки времени, добавляемые в сообщения Алисой и Бобом соответственно |
[math]\displaystyle{ R_A, R_B }[/math] | Случайные числа (nonce), которые были выбраны Алисой и Бобом соответственно |
[math]\displaystyle{ K_A, K_B, K_T }[/math] | Заранее созданные пары открытых и закрытых ключей Алисы, Боба и Трента соответственно |
[math]\displaystyle{ K_p }[/math] | Случайная сеансовая пара открытого и закрытого ключей, которая будет использоваться для асимметричного шифрования |
[math]\displaystyle{ S_A, S_B, }[/math][math]\displaystyle{ S_T, S_{K_p} }[/math] | Подписывание данных с использованием закрытого ключа Алисы, Боба, промежуточной стороны (Trent) или закрытого ключа из случайной пары соответственно |
[math]\displaystyle{ E_{K_A}, E_{K_B}, }[/math][math]\displaystyle{ E_{K_T}, E_{K_p} }[/math] | Асимметричное шифрование данных с использованием открытого ключа Алисы, Боба, промежуточной стороны (Trent) или открытого ключа из случайной пары соответственно |
Протокол DASS (англ. Distributed Authentication Security Service) — асимметричный протокол аутентификации и распределения сеансовых ключей с использованием промежуточной доверенной стороны.
Протокол DASS являлся составной частью сервиса распределённой аутентификации DASS, разработанного компанией Digital Equipment Corporation и описанного в RFC 1507[1] в сентябре 1993 года.
В протоколе DASS, по аналогии с протоколами Wide-Mouth Frog и Деннинга — Сакко, инициатор (Алиса) генерирует и новый сеансовый ключ, и, для каждого сеанса протокола, новую пару открытого и закрытого ключей отправителя. Доверенный центр (Трент) используется как хранилище сертификатов открытых ключей участников. Но в отличие от Деннинга — Сакко к доверенному центру обращаются по очереди оба участника[2].
Описание протокола
Алиса посылает сообщение Тренту на получение открытого ключа Боба
- [math]\displaystyle{ Alice \to \left\{ B \right\} \to Trent }[/math]
Трент присылает открытый ключ Боба, подписав его своим закрытым ключом
- [math]\displaystyle{ Trent \to \left\{ S_T \left(B, K_B \right) \right\} \to Alice }[/math]
Алиса проверяет данные с помощью известного ей заранее открытого ключа Трента, после чего генерирует сеансовый ключ [math]\displaystyle{ K }[/math], сеансовую пару ключей [math]\displaystyle{ K_P }[/math] и посылает набор сообщений Бобу, включая метку времени [math]\displaystyle{ T_A }[/math] и срок жизни ключа [math]\displaystyle{ L }[/math], часть из них шифруя, часть подписывая:
- [math]\displaystyle{ Alice \to \left\{ E_K \left( T_A \right) , S_A \left( L, A, K_P \right), S_{K_P} \left( E_{K_B} \left( K \right) \right) \right\} \to Bob }[/math]
Боб отправляет Тренту запрос на получение открытого ключа Алисы
- [math]\displaystyle{ Bob \to \left\{ A \right\} \to Trent }[/math]
Трент присылает открытый ключ Алисы, подписав его своим закрытым ключом
- [math]\displaystyle{ Trent \to \left\{ S_T \left(A, K_A \right) \right\} \to Bob }[/math]
Используя данные из сообщений Алисы и Трента, Боб проверяет подписи Алисы, извлекает открытый временный ключ [math]\displaystyle{ K_P }[/math], извлекает сеансовый ключ [math]\displaystyle{ K }[/math] (проверяя также подпись с использованием [math]\displaystyle{ K_P }[/math]), и расшифровывает [math]\displaystyle{ T_A }[/math] убеждаясь, что использует текущее сообщение, а не повтор.
При необходимости протокол может быть продолжен, обеспечивая взаимную идентификацию сторон:
- [math]\displaystyle{ Bob \to \left\{ E_K\left(T_B\right) \right\} \to Alice }[/math]
Алиса расшифровывает метку времени и убеждается, что получила текущее сообщение[3].
Альтернативное описание протокола
Описание протокола происходит по принципу APTC, который устраняет различия в структурах системы перехода, структуре событий и т. д. и рассматривает их поведенческие эквиваленты. Он считает, что существует два вида причинно-следственных связей: хронологический порядок, смоделированный последовательной композицией, и причинно-следственный порядок между различными параллельными ветвями, смоделированный коммуникационным слиянием. Он также считает, что существуют два вида конфликтных отношений: структурный конфликт, моделируемый альтернативной позицией, и конфликты в разных параллельных ветвях, которые должны быть устранены. Основывающийся при консервативном расширении в IPTC есть четыре модуля: BATC (Базовая алгебра для истинного Параллелизм), APTC (Алгебра для параллелизма в истинном параллелизме), рекурсия и абстракция. Подробнее …[4]
Уязвимости протокола DASS
В протоколе используется время жизни (𝐿) сеансового ключа 𝐾𝑃, однако в сообщение не включена метка времени. В результате протокол остаётся уязвимым для атаки с известным сеансовым ключом (KN). Предположим, что Меллори смогла записать полностью прошедший сеанс связи между Алисой и Бобом, а потом смогла получить доступ к сеансовому ключу 𝐾. Это позволяет Меллори аутентифицировать себя как Алиса перед Бобом.
(1) 𝑀𝑒𝑙𝑙𝑜𝑟𝑦 (𝐴𝑙𝑖𝑐𝑒) → {𝐸𝐾 (𝑇𝑀) , 𝑆𝐴 (𝐿, 𝐴, 𝐾𝑃) , 𝑆𝐾𝑃 (𝐸𝐵 (𝐾))} →𝐵𝑜𝑏
(2) 𝐵𝑜𝑏 → {𝐴} → 𝑇𝑟𝑒𝑛𝑡
(3) 𝑇𝑟𝑒𝑛𝑡 → {𝑆𝑇 (𝐴, 𝐾𝐴)} → 𝐵𝑜𝑏
(4) 𝐵𝑜𝑏 → {𝐸𝐾 {𝑇𝐵}} → 𝑀𝑒𝑙𝑙𝑜𝑟𝑦 (𝐴𝑙𝑖𝑐𝑒)
На первом проходе Меллори меняет только первое сообщение, содержащее метку времени 𝐸𝐾 (𝑇𝑀). Всё остальное Меллори копирует из записанного сеанса связи. Если Боб не записывает используемые ключи, он не заметит подмены. Простейшее исправление данной уязвимости состоит во включении метки времени в сообщение 𝑆𝐴 (𝑇𝐴, 𝐿, 𝐴, 𝐾𝑃).
Так как в протоколе сеансовый ключ 𝐾 шифруется «мастер»-ключом Боба 𝐾𝐵, то компрометация последнего приведёт к компрометации всех использованных ранее сеансовых ключей. То есть протокол не обеспечивает совершенной прямой секретности (цельG9). Ни Трент, ни Боб не участвуют в формировании новых сеансовых ключей. Поэтому Алиса может заставить Боба использовать старый сеансовый ключ, как в протоколах Wide-Mouth Frog и Yahalom[2].
Примечания
- ↑ Charles Kaufman. DASS Distributed Authentication Security Service (англ.). datatracker.ietf.org P.10 (119) (September 1993). Дата обращения: 17 сентября 2021. Архивировано 17 сентября 2021 года.
- ↑ Перейти обратно: 2,0 2,1 Владимиров С.М. Габидулин Э. М. Колыбельников А.И. Кшевецкий А. С. - Криптографические методы защиты информации. Учебное пособие.. — 2019. — С. 225,226. — 409 с.
- ↑ Bruce Schneier. Applied Cryptography, Second Edition: Protocols, Algorthms, and Source Code in C (cloth). — (Publisher: John Wiley & Sons, Inc.), 01/01/96. — С. 99—100. — 1027 с. — ISBN 0471128457.
- ↑ Yong Wang. Secure Process Algebra. — 13 Jan 2021. — С. P. 2, 103-108. — 168 с. Архивная копия от 29 октября 2021 на Wayback Machine
Литература
- Шнайер Б. Протокол DASS // Прикладная криптография. Протоколы, алгоритмы, исходные тексты на языке Си = Applied Cryptography. Protocols, Algorithms and Source Code in C. — М.: Триумф, 2002. — С. 83—84. — 816 с. — 3000 экз. — ISBN 5-89392-055-4.