Служба аутентификации и авторизации Java - Java Authentication and Authorization Service

Служба аутентификации и авторизации Java, или же JAAS, произносится как "Джаз",[1] это Ява внедрение стандарта Подключаемый модуль аутентификации (ПАМ) информационная безопасность рамки.[2]JAAS был представлен как библиотека расширения для Платформа Java, стандартная версия 1.3 и был интегрирован в версию 1.4.[1]

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

Администрация

Для Системный администратор, JAAS состоит из двух видов конфигурационный файл:

  • * .login.conf: указывает, как подключать предоставленный поставщиком авторизоваться модули в конкретные приложения
  • *.политика: указывает, каким удостоверениям (пользователям или программам) и какие разрешения предоставлены

Например, приложение может иметь это login.conf файл, указывающий, как должны запускаться различные механизмы аутентификации для аутентификации пользователя:

   PetShopApplication {com.sun.security.auth.module.LdapLoginModule достаточно; com.foo.SmartcardLoginModule Requisite; com.sun.security.auth.module.UnixLoginModule required debug = true; }

Интерфейс приложения

Для разработчика приложений JAAS - это стандартная библиотека, которая предоставляет:

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

Интеграция системы безопасности

Для интегратора систем безопасности JAAS предоставляет интерфейсы:

  • чтобы предоставить приложениям свое пространство имен
  • прикрепить учетные данные к потокам (Предмет)
  • для развития авторизоваться модули. Ваш модуль вызывает обратные вызовы для запроса пользователя, проверяет его ответ и генерирует Предмет.

Модули входа

Модули входа в систему в первую очередь связаны с аутентификацией, а не с авторизацией, и составляют широко используемый компонент JAAS. Модуль входа в систему необходим для реализации javax.security.auth.spi.LoginModule интерфейс, в котором указаны следующие методы:

Примечание: A Предмет это пользователь, который пытается войти в систему.

  • инициализировать: Код для инициализации модуля входа в систему, обычно путем сохранения параметров, переданных в соответствующие поля Учебный класс.
  • авторизоваться: Фактически проверьте учетные данные, предоставленные через Объект который реализует javax.security.auth.Callback интерфейс (например, проверка по базе данных). Этот метод может запрашивать у пользователя логин и пароль или использовать ранее полученные данные. Здесь важно отметить, что если предоставлены недопустимые учетные данные, то javax.security.auth.login.FailedLoginException должен быть выдан (вместо того, чтобы возвращать false, что указывает на то, что этот модуль входа в систему следует игнорировать, что потенциально позволяет пройти аутентификацию).
  • совершить: Личность субъекта подтверждена, поэтому код в этом методе устанавливает Главный и Группы (роли) для успешно аутентифицированного субъекта. Этот метод должен быть тщательно написан в корпоративных приложениях, поскольку серверы приложений Java EE часто ожидают взаимосвязи между Главный и Группа объекты, которые нужно настроить определенным образом. Этот метод должен вызывать javax.security.auth.login.FailedLoginException в случае сбоя аутентификации (например, пользователь указал неверный логин или пароль).
  • прервать: Вызывается, если сам процесс аутентификации терпит неудачу. Если этот метод возвращает false, этот модуль входа в систему игнорируется.
  • выйти: Код, который должен выполняться при выходе из системы (например, можно удалить Главный от Предмет или может аннулировать веб-сеанс).

Модули входа в систему могут обеспечивать единый вход (SSO) через определенный протокол / структуру SSO (например, SAML, OpenID, и СПНЕГО ), может проверять наличие аппаратных токенов безопасности (например, USB-токена) и т. д. В многоуровневом приложении ВходМодули может присутствовать как на стороне клиента, так и на стороне сервера.

LoginModule (javax.security.auth.spi.LoginModule)

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

LoginContext (javax.security.auth.login.LoginContext)

Контекст входа в систему - это ядро ​​инфраструктуры JAAS, которая запускает процесс аутентификации с создания субъекта. По мере продолжения процесса аутентификации субъект заполняется различными участниками и учетными данными для дальнейшей обработки.

Предмет (javax.security.auth.Subject)

Субъект представляет отдельного пользователя, объект или систему, другими словами, клиента, запрашивающего аутентификацию.

Главный (java.security.Principal)

Директор представляет лицо предмета. Он инкапсулирует особенности или свойства предмета. Тема может содержать несколько участников.

Реквизиты для входа

Полномочия - это не что иное, как информация о рассматриваемом предмете. Это могут быть номера учетных записей, пароли, сертификаты и т. Д. Поскольку учетные данные представляют некоторую важную информацию, дополнительные интерфейсы могут быть полезны для создания правильных и безопасных учетных данных - javax.security.auth.Destroyable и javax.security.auth.Refreshable. Предположим, что после успешной аутентификации пользователя вы заполняете субъект секретным идентификатором (в форме учетных данных), с помощью которого субъект может выполнять некоторые важные службы, но учетные данные должны быть удалены через определенное время. В этом случае может потребоваться реализовать Разрушаемый интерфейс. Освежаемый может быть полезно, если учетные данные действительны только в течение ограниченного периода времени.

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

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

  1. ^ а б Теодор Дж. Шрейдер; Брюс А. Рич; Энтони Дж. Надалин. Java и интернет-безопасность. п. 152.
  2. ^ «Справочное руководство по службе аутентификации и авторизации Java (JAAS)». oracle.com. Корпорация Oracle. Архивировано из оригинал 26 сентября 2012 г.. Получено 22 мая 2012.

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