Одноразовый пароль

Пароль, который можно использовать только один раз
MasterCard SecureCode использует OTAC для подтверждения личности пользователя
Одноразовый код авторизации, используемый в клиенте Yammer для настольных ПК

Одноразовый пароль ( OTP ), также известный как одноразовый PIN-код , одноразовый код доступа , одноразовый код авторизации ( OTAC ) или динамический пароль , — это пароль, который действителен только для одного сеанса входа или транзакции в компьютерной системе или другом цифровом устройстве. OTP позволяют избежать нескольких недостатков, связанных с традиционной (статической) аутентификацией на основе пароля; ряд реализаций также включают двухфакторную аутентификацию , гарантируя, что одноразовый пароль требует доступа к чему-то, что есть у человека (например, к небольшому брелоку-устройству со встроенным в него калькулятором OTP, или к смарт-карте или определенному мобильному телефону), а также к чему-то, что человек знает (например, к PIN-коду).

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

OTP обсуждались как возможная замена, а также как улучшение традиционных паролей. С другой стороны, OTP могут быть перехвачены или перенаправлены, а жесткие токены могут быть утеряны, повреждены или украдены. Многие системы, использующие OTP, не реализуют их безопасно, и злоумышленники все равно могут узнать пароль с помощью фишинговых атак , чтобы выдать себя за авторизованного пользователя. [1]

Характеристики

Самое важное преимущество, на которое направлены OTP, заключается в том, что, в отличие от статических паролей, они не уязвимы для атак с повторным воспроизведением . Это означает, что потенциальный злоумышленник, которому удастся записать OTP, который уже использовался для входа в службу или для проведения транзакции, не сможет его использовать, поскольку он больше не будет действительным. [1] Второе важное преимущество заключается в том, что пользователь, который использует один и тот же (или похожий) пароль для нескольких систем, не становится уязвимым во всех из них, если пароль для одной из них будет получен злоумышленником. Ряд систем OTP также направлены на то, чтобы гарантировать, что сеанс нельзя будет легко перехватить или подделать без знания непредсказуемых данных, созданных во время предыдущего сеанса, тем самым еще больше сокращая поверхность атаки .

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

В некоторых схемах математических алгоритмов пользователь может предоставить серверу статический ключ для использования в качестве ключа шифрования, отправив только одноразовый пароль. [2]

Поколение

Конкретные алгоритмы OTP сильно различаются в деталях. Различные подходы к генерации OTP включают:

  • Основано на синхронизации времени между сервером аутентификации и клиентом, предоставляющим пароль (OTP действительны только в течение короткого периода времени)
  • Использование математического алгоритма для генерации нового пароля на основе предыдущего пароля (OTP фактически представляют собой цепочку и должны использоваться в предопределенном порядке).
  • Использование математического алгоритма, в котором новый пароль основан на вызове (например, случайном числе, выбранном сервером аутентификации или данными транзакции) и/или счетчике.

Синхронизировано по времени

Синхронизированный по времени OTP обычно связан с частью оборудования, называемого токеном безопасности (например, каждому пользователю выдается персональный токен, который генерирует одноразовый пароль). Он может выглядеть как небольшой калькулятор или брелок для ключей с ЖК-дисплеем, на котором время от времени отображается число. Внутри токена находятся точные часы, синхронизированные с часами на сервере аутентификации . В этих системах OTP время является важной частью алгоритма паролей, поскольку генерация новых паролей основана на текущем времени, а не на предыдущем пароле или секретном ключе или в дополнение к ним . Этот токен может быть фирменным устройством или мобильным телефоном или аналогичным мобильным устройством , на котором работает фирменное, бесплатное или открытое программное обеспечение . Примером стандарта синхронизированного по времени OTP является основанный на времени одноразовый пароль (TOTP). Некоторые приложения могут использоваться для хранения синхронизированного по времени OTP, например Google Authenticator или менеджер паролей .

Хэш-цепочки

Каждый новый OTP может быть создан из ранее использованных OTP. Пример такого типа алгоритма, приписываемый Лесли Лэмпорту , использует одностороннюю функцию (назовем ее ). Эта система одноразовых паролей работает следующим образом: ф {\displaystyle f}

  1. Выбирается начальное значение (начальное число) . с {\displaystyle с}
  2. Функция хэширования применяется многократно (например, 1000 раз) к начальному числу, давая значение: . Это значение, которое мы назовем , хранится в целевой системе. ф ( с ) {\displaystyle f(s)} ф ( ф ( ф ( ф ( с ) ) ) ) {\displaystyle f(f(f(\ldots f(s)\ldots )))} ф 1000 ( с ) {\displaystyle f^{1000}(с)}
  3. Первый вход пользователя в систему использует пароль, полученный путем применения 999 раз к зерну, то есть . Целевая система может подтвердить, что это правильный пароль, поскольку это , что является сохраненным значением. Затем сохраненное значение заменяется на , и пользователю разрешается войти в систему. п {\displaystyle p} ф {\displaystyle f} ф 999 ( с ) {\displaystyle f^{999}(с)} ф ( п ) {\displaystyle f(p)} ф 1000 ( с ) {\displaystyle f^{1000}(с)} п {\displaystyle p}
  4. Следующий вход должен сопровождаться . Опять же, это можно проверить, потому что хеширование дает , значение , сохраненное после предыдущего входа. Опять же, новое значение заменяет и пользователь аутентифицируется. ф 998 ( с ) {\displaystyle f^{998}(с)} ф 999 ( с ) {\displaystyle f^{999}(с)} п {\displaystyle p} п {\displaystyle p}
  5. Это можно повторить еще 997 раз, каждый раз пароль будет применяться на один раз меньше, и проверяется проверкой того, что при хэшировании он дает значение, сохраненное во время предыдущего входа в систему. Хэш-функции разработаны так, чтобы их было крайне сложно обратить вспять, поэтому злоумышленнику нужно знать начальное начальное число для вычисления возможных паролей, в то время как компьютерная система может подтвердить, что пароль в любом случае действителен, проверив, что при хэшировании он дает значение, ранее использованное для входа в систему. Если требуется неопределенная серия паролей, можно выбрать новое начальное значение после того, как набор будет исчерпан. ф {\displaystyle f} с {\displaystyle с} с {\displaystyle с}
  6. Хотя значение счетчика сервера увеличивается только после успешной аутентификации OTP, счетчик на токене увеличивается каждый раз, когда пользователь запрашивает новый пароль. Из-за этого значения счетчика на сервере и на токене могут быть не синхронизированы. Рекомендуется установить параметр look-ahead на сервере, который определяет размер окна look-ahead. В случае случайной генерации пароля пользователем сервер все равно аутентифицирует клиента, поскольку он может пересчитать следующие значения OTP-сервера и проверить их с полученным паролем от клиента. [3] х {\displaystyle x} х {\displaystyle x}

Чтобы получить следующий пароль в серии из предыдущих паролей, нужно найти способ вычисления обратной функции . Поскольку была выбрана односторонней, это сделать крайне сложно. Если является криптографической хэш-функцией , что обычно и бывает, то предполагается, что это вычислительно неразрешимая задача. Злоумышленник, который случайно увидел одноразовый пароль, может получить доступ на один период времени или войти в систему, но он становится бесполезным по истечении этого периода. Система одноразовых паролей S/KEY и ее производный OTP основаны на схеме Лампорта. ф 1 {\displaystyle f^{-1}} ф {\displaystyle f} ф {\displaystyle f}

Вызов-ответ

Использование одноразовых паролей типа «вызов-ответ» требует от пользователя предоставить ответ на вызов. Например, это можно сделать, введя значение, которое сгенерировал токен, в сам токен. Чтобы избежать дубликатов, обычно используется дополнительный счетчик, поэтому если кто-то получает один и тот же вызов дважды, это все равно приводит к разным одноразовым паролям. Однако вычисление обычно [ необходима цитата ] не включает в себя предыдущий одноразовый пароль; то есть обычно используется этот или другой алгоритм, а не оба алгоритма.

Реализации

SMS

Распространенной технологией, используемой для доставки одноразовых паролей, является текстовое сообщение . Поскольку текстовое сообщение является повсеместным каналом связи, доступным напрямую практически на всех мобильных телефонах и, посредством преобразования текста в речь, на любом мобильном или стационарном телефоне, текстовое сообщение имеет большой потенциал для охвата всех потребителей с низкой общей стоимостью внедрения. Одноразовые пароли в текстовых сообщениях могут быть зашифрованы с использованием стандарта A5/x , который, как сообщают несколько хакерских групп, может быть успешно расшифрован в течение нескольких минут или секунд. [4] [5] [6] [7] Кроме того, недостатки безопасности в протоколе маршрутизации SS7 могут и использовались для перенаправления связанных текстовых сообщений злоумышленникам; в 2017 году несколько клиентов O2 в Германии были взломаны таким образом, чтобы получить доступ к их счетам мобильного банкинга . В июле 2016 года NIST США выпустил проект специальной публикации с руководством по методам аутентификации, в котором не рекомендуется использовать SMS в качестве метода реализации внеполосной двухфакторной аутентификации из-за возможности перехвата SMS в больших масштабах. [8] [9] [10] Текстовые сообщения также уязвимы для мошенничества с подменой SIM-карты , когда злоумышленник обманным путем переносит номер телефона жертвы на свою собственную SIM-карту , которую затем можно использовать для получения доступа к отправляемым на нее сообщениям. [11] [12]

Аппаратные токены

Токены безопасности RSA SecurID .

SecurID от RSA Security является одним из примеров типа токена синхронизации времени, наряду с решениями HID Global . Как и все токены, они могут быть утеряны, повреждены или украдены; кроме того, есть неудобство, поскольку батареи разряжаются, особенно для токенов без возможности подзарядки или с несменной батареей. Вариант фирменного токена был предложен RSA в 2006 году и был описан как «повсеместная аутентификация», в рамках которой RSA будет сотрудничать с производителями для добавления физических чипов SecurID в такие устройства, как мобильные телефоны.

Недавно [ когда? ] стало возможным брать электронные компоненты, связанные с обычными брелоками OTP-токенами, и встраивать их в форм-фактор кредитной карты. Однако тонкость карт, толщиной от 0,79 мм до 0,84 мм, не позволяет использовать стандартные компоненты или батареи. Необходимо использовать специальные батареи на основе полимеров , которые имеют гораздо меньший срок службы, чем монетные (кнопочные) элементы . Полупроводниковые компоненты должны быть не только очень плоскими, но и минимизировать мощность, используемую в режиме ожидания и при работе. [ нужна цитата ]

Yubico предлагает небольшой USB-токен со встроенным чипом, который создает одноразовый пароль при нажатии клавиши и имитирует клавиатуру, чтобы облегчить ввод длинного пароля. [13] Поскольку это USB-устройство, оно позволяет избежать неудобств, связанных с заменой батареи.

Разработана новая версия этой технологии, которая встраивает клавиатуру в платежную карту стандартного размера и толщины. Карта имеет встроенную клавиатуру, дисплей, микропроцессор и чип бесконтактного считывания.

Мягкие токены

Пример мягкого токена .

На смартфонах одноразовые пароли также могут быть доставлены напрямую через мобильные приложения , включая специальные приложения аутентификации, такие как Authy и Google Authenticator , или в существующем приложении сервиса, например, в случае Steam . Эти системы не имеют тех же уязвимостей безопасности, что и SMS, и не обязательно требуют подключения к мобильной сети для использования. [14] [10] [15]

Печатные копии

Одноразовые пароли на бумажном носителе.

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

Безопасность

При правильной реализации одноразовые пароли перестают быть полезными для злоумышленника в течение короткого времени после их первоначального использования. Это отличается от паролей, которые могут оставаться полезными для злоумышленников годы спустя.

Как и пароли, OTP уязвимы для атак социальной инженерии , в которых фишеры крадут OTP, обманывая клиентов, чтобы те предоставили им свои OTP. Также, как и пароли, OTP могут быть уязвимы для атак типа «человек посередине» , поэтому важно передавать их по защищенному каналу, например, Transport Layer Security .

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

OTP, которые не включают в себя синхронизацию времени или компонент «вызов-ответ», обязательно будут иметь более длительное окно уязвимости, если они были скомпрометированы до их использования. В конце 2005 года клиенты шведского банка были обмануты, выдав свои заранее предоставленные одноразовые пароли. [16] В 2006 году этот тип атаки был использован против клиентов американского банка. [17]

Стандартизация

Многие технологии OTP запатентованы. Это затрудняет стандартизацию в этой области, поскольку каждая компания пытается продвинуть свою собственную технологию. Однако стандарты существуют — например, RFC 1760 ( S/KEY ), RFC 2289 (OTP), RFC 4226 ( HOTP ) и RFC 6238 ( TOTP ).

Использовать

Мобильный телефон

Мобильный телефон сам по себе может быть ручным маркером аутентификации . [18] Мобильный текстовый обмен сообщениями является одним из способов получения OTAC через мобильный телефон. Таким образом, поставщик услуг отправляет текстовое сообщение, которое включает OTAC, зашифрованный цифровым сертификатом, пользователю для аутентификации. Согласно отчету, мобильный текстовый обмен сообщениями обеспечивает высокую безопасность, когда он использует инфраструктуру открытых ключей (PKI) для обеспечения двунаправленной аутентификации и неотказуемости в соответствии с теоретическим анализом. [19]

SMS как метод получения OTAC широко используется в нашей повседневной жизни для таких целей, как банковское дело, кредитные/дебетовые карты и безопасность. [20] [21] [22]

Телефон

Существует два способа использования телефона для проверки подлинности пользователя.

При первом методе поставщик услуг показывает OTAC на экране компьютера или смартфона, а затем совершает автоматический телефонный звонок на номер, который уже был аутентифицирован. Затем пользователь вводит OTAC, который появляется на его экране, на клавиатуру телефона. [23]

При использовании второго метода, который используется для аутентификации и активации Microsoft Windows , пользователь звонит по номеру, предоставленному поставщиком услуг, и вводит OTAC, который телефонная система выдает пользователю. [24]

Компьютер

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

  • Электронная почта является одним из распространенных способов использования OTAC. Существует два основных метода. При первом методе поставщик услуг отправляет персонализированный одноразовый URL на аутентифицированный адрес электронной почты, например @ucl.ac.uk; когда пользователь нажимает на URL, сервер аутентифицирует пользователя. [25] При втором методе поставщик услуг отправляет персонализированный OTAC (например, зашифрованный токен) на аутентифицированный адрес электронной почты; когда пользователь вводит OTAC на веб-сайте, сервер аутентифицирует пользователя. [ необходима цитата ]
  • Веб -приложение может генерировать уникальный персональный идентификационный номер (PIN-код), который пользователь может ввести в клиент настольного компьютера, клиент настольного компьютера, в свою очередь, использует этот код для аутентификации себя в веб-приложении . Эта форма аутентификации особенно полезна в веб-приложениях, которые не имеют внутреннего хранилища имени пользователя/пароля, а вместо этого используют SAML для аутентификации. Поскольку SAML работает только в браузере, клиент веб-приложения на базе настольного компьютера не может успешно пройти аутентификацию с использованием SAML . Вместо этого клиентское приложение может использовать одноразовый код авторизации (OTAC) для аутентификации себя в веб-приложении . Кроме того, можно использовать фреймворк авторизации OAuth , когда стороннему приложению необходимо получить ограниченный доступ к службе HTTP. [26]

Почта

Можно отправлять OTAC пользователю по почте или заказным письмом . Когда пользователь запрашивает OTAC, поставщик услуг отправляет его по почте или заказным письмом, а затем пользователь может использовать его для аутентификации. Например, в Великобритании некоторые банки отправляют свои OTAC для авторизации интернет-банкинга по почте или заказным письмом . [27]

Расширение

Квантовая криптография , основанная на принципе неопределенности, является одним из идеальных методов создания OTAC. [28]

Более того, обсуждалось и использовалось не только использование зашифрованного кода для аутентификации, но и использование графической одноразовой аутентификации PIN-кода [29], такой как QR-код , который обеспечивает децентрализованную технику контроля доступа с анонимной аутентификацией. [30] [31]

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

Ссылки

  1. ^ ab Paterson, Kenneth G.; Stebila, Douglas (2010). "One-Time-Password-Authenticated Key Exchange" (PDF) . В Steinfeld, Ron; Hawkes, Philip (ред.). Information Security and Privacy . Lecture Notes in Computer Science. Vol. 6168. Berlin, Heidelberg: Springer. pp.  264– 281. doi :10.1007/978-3-642-14081-5_17. ISBN 978-3-642-14081-5.
  2. ^ EOTP – Статическая передача ключа. Defuse.ca (13 июля 2012 г.). Получено 21 декабря 2012 г.
  3. ^ Инструменты IETF. RFC 4226 — Раздел 7.4: Ресинхронизация счетчика
  4. ^ Баркан, Элад; Эли Бихам ; Натан Келлер (2003). «Мгновенный криптоанализ только зашифрованного текста зашифрованной связи GSM»: 600–16 . Архивировано из оригинала 7 октября 2015 г. Получено 6 октября 2015 г. {{cite journal}}: Цитировать журнал требует |journal=( помощь )
  5. ^ Баркан, Элад; Эли Бихам; Натан Келлер. «Мгновенный криптоанализ зашифрованной связи GSM только на основе шифротекста, проведенный Барканом и Бихамом из Техниона (полная версия)» (PDF) .
  6. ^ Генейсу, Тим; Тимо Каспер; Мартин Новотны; Кристоф Паар; Энди Рапп (2008). «Криптоанализ с помощью COPACOBANA» (PDF) . IEEE Transactions on Computers . 57 (11): 1498– 1513. doi :10.1109/TC.2008.80. S2CID  8754598.
  7. ^ Ноль, Карстен; Крис Пейджет (27 декабря 2009 г.). GSM: SRSLY?. 26th Chaos Communication Congress (26C3) . Получено 30 декабря 2009 г.
  8. ^ Фонтана, Джон. «Блог NIST разъясняет необходимость отмены SMS в связи с упадком СМИ». ZDNet . Получено 14 июля 2017 г.
  9. ^ Мейер, Дэвид. «Время уходит для кодов безопасности входа на основе SMS». Fortune . Получено 14 июля 2017 г.
  10. ^ ab Brandom, Russell (10 июля 2017 г.). «Двухфакторная аутентификация — это беспорядок». The Verge . Получено 14 июля 2017 г. .
  11. ^ Брэндом, Рассел (31 августа 2019 г.). «Пугающе простая техника, которая похитила аккаунт Джека Дорси в Twitter». The Verge . Получено 30 января 2020 г. .
  12. ^ Тимс, Анна (26 сентября 2015 г.). «Подмена SIM-карты дает мошенникам доступ ко всем зонам через ваш мобильный телефон». The Guardian . ISSN  0261-3077 . Получено 30 января 2020 г.
  13. ^ "Yubico AB". Bloomberg Businessweek . Архивировано из оригинала 14 октября 2012 года . Получено 13 июля 2011 года .
  14. ^ Гарун, Натт (17 июня 2017 г.). «Как настроить двухфакторную аутентификацию на всех ваших онлайн-аккаунтах». The Verge . Получено 14 июля 2017 г. .
  15. ^ МакВертор, Майкл (15 апреля 2015 г.). «Valve добавляет двухфакторную аутентификацию при входе в мобильное приложение Steam». Polygon . Получено 8 сентября 2015 г.
  16. ^ Статья в The Register. Статья в The Register (12 октября 2005 г.). Получено 21.12.2012.
  17. ^ Блог по безопасности Washington Post. Blog.washingtonpost.com. Получено 21 декабря 2012 г.
  18. ^ Ву, М., Гарфинкель, С. и Миллер, Р. (2004). Безопасная веб-аутентификация с помощью мобильных телефонов. С. 9–10.
  19. ^ Шу, М., Тан, К. и Ван, Х. (2009). Схема мобильной аутентификации с использованием SMS. Наука, менеджмент и инжиниринг в сфере услуг, 2009. SSME '09. Международная конференция IITA, стр. 161–164.
  20. ^ Axisbank.com, (nd). Регистрация мобильного приложения Axis Bank. [онлайн] Доступно по адресу: http://www.axisbank.com/personal/speed-banking/how-to-download-and-register-java.aspx [Доступ 28 октября 2014 г.].
  21. ^ Master Card Secure Code. (nd). [онлайн] Доступно по адресу: http://www.ingvysyabank.com/pdf's/What%20is%20MasterCard%20SecureCode.pdf [Дата обращения 28 октября 2014 г.].
  22. ^ Inc., S. (nd). SMS-аутентификация: SafeNet Authentication Services. [онлайн] Www2.safenet-inc.com. Доступно по адресу: http://www2.safenet-inc.com/sas/sms-tokens.html [Дата обращения 28 октября 2014 г.].
  23. ^ Lloydsbank.com, (nd). Процедура аутентификации Lloyds Bank Online. [онлайн] Доступно по адресу: http://www.lloydsbank.com/help-guidance/security/authentication-procedure.asp?srnum=1 [Дата обращения 28 октября 2014 г.].
  24. ^ windows.microsoft.com, (nd). Активация Windows 7. [онлайн] Доступно по адресу: http://windows.microsoft.com/en-us/windows/activate-windows#1TC=windows-7 [Доступ 28 октября 2014 г.].
  25. ^ Адида, Б. (2008). EmID: Веб-аутентификация по адресу электронной почты.
  26. ^ Хардт, Д. (2012). Структура авторизации OAuth 2.0.
  27. ^ Lloydsbank.com, (nd). Lloyds Bank — Интернет-банкинг — Как зарегистрироваться для онлайн-банкинга. [онлайн] Доступно по адресу: http://www.lloydsbank.com/online-banking/how-to-register.asp [Дата обращения 28 октября 2014 г.].
  28. ^ Sobota,, M., Kapczy_ski, A. и Banasik, A. (2011). Применение протоколов квантовой криптографии в процессе аутентификации. Интеллектуальные системы сбора данных и передовые вычислительные системы (IDAACS), 2011 IEEE 6-я международная конференция, 2, стр. 799–802.
  29. ^ Джавар, Р., Инглесант, П., Куртуа, Н. и Сасс, М. (2011). Сделайте мой четверной: укрепление безопасности графической одноразовой аутентификации с помощью ПИН-кода. С. 81–88.
  30. ^ Ляо, К. и Ли, В. (2010). Новая схема аутентификации пользователя на основе QR-кода. Журнал сетей, 5(8), стр. 937–941.
  31. ^ Виджаялакшми, А. и Арунаприя, Р. (2014). АУТЕНТИФИКАЦИЯ ХРАНИЛИЩА ДАННЫХ С ИСПОЛЬЗОВАНИЕМ ДЕЦЕНТРАЛИЗОВАННОГО КОНТРОЛЯ ДОСТУПА В ОБЛАКАХ. Журнал глобальных исследований в области компьютерных наук, 5(9), стр. 1–4.
Взято с "https://en.wikipedia.org/w/index.php?title=Одноразовый_пароль&oldid=1269070633#Синхронизировано по времени"