Symfony 3.4 - Шифрование ПЕРЕД login_check. Аутентификация

В настоящее время я использую Symfony 3 и работаю над аутентификацией. Мои пароли в базе зашифрованы. Для аутентификации symfony возвращает данные, отправленные через форму соединения, и передает их в мой корень login_check. Я хочу зашифровать пароль пользователя до того, как symfony передаст его в login_check. Вот часть моего security.yml. Если вам нужна дополнительная информация, не стесняйтесь обращаться ко мне. Спасибо большое !

PS: извините за мой английский ^^

intranet:
        pattern:   ^/intranet
        anonymous: ~
        provider:     Auditeurs
        form_login:
            default_target_path: intranet_dashboard
            login_path: intranet_login
            check_path: intranet_login_check
        logout:
            path:       intranet_logout #nom de la route
            target:     /intranet/


providers:
    Auditeurs:
        entity:
            class:    AppBundle\Entity\Auditeur
            property: username
Стоит ли изучать PHP в 2026-2027 годах?
Стоит ли изучать PHP в 2026-2027 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Symfony Station Communiqué - 7 июля 2023 г
Symfony Station Communiqué - 7 июля 2023 г
Это коммюнике первоначально появилось на Symfony Station .
Оживление вашего приложения Laravel: Понимание режима обслуживания
Оживление вашего приложения Laravel: Понимание режима обслуживания
Здравствуйте, разработчики! В сегодняшней статье мы рассмотрим важный аспект управления приложениями, который часто упускается из виду в суете...
Установка и настройка Nginx и PHP на Ubuntu-сервере
Установка и настройка Nginx и PHP на Ubuntu-сервере
В этот раз я сделаю руководство по установке и настройке nginx и php на Ubuntu OS.
Коллекции в Laravel более простым способом
Коллекции в Laravel более простым способом
Привет, читатели, сегодня мы узнаем о коллекциях. В Laravel коллекции - это способ манипулировать массивами и играть с массивами данных. Благодаря...
Как установить PHP на Mac
Как установить PHP на Mac
PHP - это популярный язык программирования, который используется для разработки веб-приложений. Если вы используете Mac и хотите разрабатывать...
0
0
49
1

Ответы 1

Как только запрос login_check попадает в ваше приложение Symfony, он отправляется на брандмауэр, который хеши пароль и сравнивает его с базой данных. Следовательно, «шифрование» перед этим не совсем имеет смысла, у вас просто выполняется несколько строк маршрутизации «сантехника». Скорее всего, вы захотите хэшировать пароли на стороне клиента, используя некоторую библиотеку Javascript. Такой есть SJCL.

Однако преимущества такого подхода минимальны, если ваш сайт обслуживается по HTTPS (как и должно быть).

Последнее замечание: пароль - хешированный (с использованием кодировщик из конфигурации Symfony), а не зашифрованный. Хеш - это односторонняя функция. С другой стороны, зашифрованные пароли можно восстановить из базы данных (чего никогда не должно происходить). Рекомендуется BCrypt (я подозреваю, что теперь это значение по умолчанию в Symfony).

Если вы хэшируете пароли на стороне клиента, то хешируете является пароль, и у вас все равно возникают те же проблемы с открытым текстом / воспроизведением. Используйте HTTPS.

Sammitch 16.03.2018 18:48

Не могли бы вы подробно описать сценарий такой атаки? Думаю, дело не в утечке пароля зашифрованного текста, но повторы можно настроить множеством разных способов, если соединение будет перехвачено (например, файлы cookie). Поэтому советуем использовать HTTPS.

romaricdrigon 19.03.2018 09:12

Другие вопросы по теме