Вместо использования IAuthorizationFilter, который предназначен для авторизации, для аутентификации API-ключей рекомендуется создать собственный
Валидация API-ключей начинается с создания интерфейса валидатора, который проверяет ключ и возвращает результат, включая информацию об ошибке или данные пользователя.
Метод
Для интеграции с Core, необходимо зарегистрировать обработчик и настроить схему аутентификации. Для этого в методе
AuthenticationHandler
, расширив AuthenticationHandler<TOptions>
. Это обеспечивает лучшее разделение обязанностей, позволяя обрабатывать аутентификацию на уровне middleware. Ключи должны передаваться через HTTPS, генерироваться криптографически безопасным способом, безопасно храниться (возможно, зашифрованными) и регулярно обновляться. Не следует раскрывать их в URL, логах или сообщениях об ошибках. Рекомендуется ограничивать разрешения ключей областями действия. Изображение носит иллюстративный характер
Валидация API-ключей начинается с создания интерфейса валидатора, который проверяет ключ и возвращает результат, включая информацию об ошибке или данные пользователя.
ApiKeyAuthenticationHandler
отвечает за извлечение ключа из запроса (обычно из заголовка X-API-Key
), его валидацию и создание контекста пользователя в случае успешной проверки. В случае неудачи запрос должен быть отклонен. При использовании областей (scopes) в API, обработчик также может устанавливать утверждения политики. Метод
HandleChallengeAsync
переопределяется для отправки HTTP-ответа 401 Unauthorized в случае, если аутентификация не удалась, включая информацию о требуемой схеме аутентификации, например, в виде заголовка WWW-Authenticate: ApiKey
. Для улучшения дизайна API также рекомендуется использовать problem details для возврата структурированного сообщения об ошибке. Для интеграции с Core, необходимо зарегистрировать обработчик и настроить схему аутентификации. Для этого в методе
AddAuthentication
устанавливается схема по умолчанию, затем добавляется кастомный обработчик через метод AddScheme
, а также регистрируется валидатор API-ключей. Такой подход позволяет гибко управлять аутентификацией в вашем API.