Комментарии:

1. Комментатор 1: Обратил внимание на отсутствие обработки ситуации, когда refresh токен просрочен. Предлагает добавить перенаправление на страницу логина в таком случае.
Комментарии:
Изображение носит иллюстративный характер

  • Комментатор 2: Предложил использовать axios.interceptors для автоматического добавления токена в каждый запрос и автоматического обновления токена, а не в каждом конкретном запросе.
  • Комментатор 3: Сделал замечание, что проверка CSRF на GET запросах избыточна.
  • Комментатор 4: Указал, что использование localStorage для имени пользователя и статуса не является безопасным, так как они могут быть изменены. Предложил использовать более безопасное место для хранения такой информации.
  • Комментатор 5: Добавил, что для полного понимания безопасности необходимо помнить об XSS, так как httponly защищает только от JavaScript.
  • Комментатор 6: Отметил, что установка Secure=True для cookie необходима в production режиме, а также добавление CORS настроек для поддержки credentials.
  • Комментатор 7: Сообщил, что для работы с JWT токенами можно использовать Refresh Token Rotation, что позволяет выпустить новый Refresh token при каждом обновлении.
  • Комментатор 8: Заметил, что использование response.data.get('access') может вызвать ошибку, если токен не будет в ответе, поэтому лучше использовать response.data?.access
  • Комментатор 9: Напомнил, что необходимо правильно настраивать CORS, а также можно защитить endpoints от CSRF атак на бэке с помощью декоратора @ensure_csrf_cookie.
  • Комментатор 10: Уточнил, что secure=True для cookie должно быть всегда True для продакшн. А в development можно поставить False в целях тестирования.

 Безопасная аутентификация с JWT через Cookies: улучшенная стратегия

Перенос JWT токенов в HTTP-only cookies повышает безопасность, предотвращая XSS атаки на локальное хранилище браузера. Ключевым моментом является настройка флагов HttpOnly, Secure (обязательно для HTTPS) и SameSite для кук, что минимизирует риски.

Для авторизации используется специальный сериализатор, который возвращает дополнительные данные пользователя. Важно применять CSRF защиту для всех POST запросов с помощью декоратора, который проверяет CSRF токен, добавляемый в заголовок. При этом проверка CSRF токена для GET запросов не требуется.

В React, HTTP-клиент должен автоматически обрабатывать куки, передавая их в каждом запросе, а также отлавливать случаи просроченного refresh токена, при которых пользователь должен быть перенаправлен на страницу входа. Применяйте interceptors axios для автоматизации процесса обновления токена.

Для хранения данных о пользователе (имя, статус) следует избегать небезопасного localStorage. Рассмотрите более защищенные альтернативы. Помните про необходимость правильной настройки CORS для работы с credentials. Кроме того, важно использовать Refresh Token Rotation для повышения безопасности токенов.

Учитывайте возможность получения ошибки при доступе к response.data.access и обрабатывайте этот вариант, а также убедитесь, что вы защищаете свои endpoints с помощью декоратора @ensure_csrf_cookie на сервере. Наконец, secure=True для cookie необходимо установить в True для production, а в development при необходимости можно выставить False для тестирования.


Новое на сайте

19521Банковский троян VENON на Rust атакует Бразилию с помощью девяти техник обхода защиты 19520Бонобо агрессивны не меньше шимпанзе, но всё решают самки 19519Почему 600-килограммовый зонд NASA падает на Землю из-за солнечной активности? 19518«Липовый календарь»: как расписание превращает работников в расходный материал 19517Вредоносные Rust-пакеты и ИИ-бот крадут секреты разработчиков через CI/CD-пайплайны 19516Как хакеры за 72 часа превратили npm-пакет в ключ от целого облака AWS 19515Как WebDAV-диск и поддельная капча помогают обойти антивирус? 19514Могут ли простые числа скрываться внутри чёрных дыр? 19513Метеорит пробил крышу дома в Германии — откуда взялся огненный шар над Европой? 19512Уязвимости LeakyLooker в Google Looker Studio открывали доступ к чужим базам данных 19511Почему тысячи серверов оказываются открытой дверью для хакеров, хотя могли бы ею не быть? 19510Как исследователи за четыре минуты заставили ИИ-браузер Perplexity Comet попасться на... 19509Может ли женщина без влагалища и шейки матки зачать ребёнка естественным путём? 19508Зачем учёные из Вены создали QR-код, который невозможно увидеть без электронного... 19507Девять уязвимостей CrackArmor позволяют получить root-доступ через модуль безопасности...
Ссылка