Запретить доступ в методе Symfony, если вы не находитесь в localhost

Я хочу знать как запретить доступ методу контроллера что он не вызывается с localhost. Например, я хотел бы разрешить доступ к этому URL-адресу www.myweb.com/usermanagement, только если вы находитесь на локальном хосте.

Я ничего не нашел в документе https://symfony.com/doc/3.2/security.html

Стоит ли изучать 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
405
2
Перейти к ответу Данный вопрос помечен как решенный

Ответы 2

Посмотрите в access_control документация. Вы можете использовать ключ allow_if и сделать что-то вроде этого:

access_control:
    - path: ^/usermanagement
      allow_if: "request.getHost() == 'localhost'"
Ответ принят как подходящий

Во-первых, решение fxbt отличное.

Но вы также можете сделать это, используя конфигурацию брандмауэра в файле security.yaml: https://symfony.com/doc/3.2/security/firewall_restriction.html

# app/config/security.yml

# ...
security:
    firewalls:
        # This is a custom firewall area and may conflict with your existing firewall
        other_secured_area:
            host: ^localhost$
            pattern: ^/usermanagement

Другое решение - сделать это прямо в контроллере:

public function userManagement(Request $request)
{
    if ($request->getHost() !== 'localhost') {
        throw new $this->createAccessDeniedException();
    }
}

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

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