Symfony2: onKernelResponse вызывается дважды как MASTER_REQUEST

Я использую прослушиватель событий onKernelResponse.

Несмотря на то, что я использовал:

if (HttpKernelInterface::MASTER_REQUEST != $event->getRequestType()) {
    return;
}

В моем действии дважды есть MASTER_REQUEST, один перед <!DOCTYPE html> <html> <head>etc, а другой, как исключение, после конца макета.

He is my services.yml :

history.listener:
    class: VENDOR\MyBundle\Service\HistoryListener
    arguments: [@doctrine.orm.entity_manager, @logger, @history]
    tags:
        - { name: kernel.event_listener, event: kernel.controller, method: onKernelController }
        - { name: kernel.event_listener, event: kernel.response, method: onKernelResponse }

Я сделал что-то неправильно ?


person Bonswouar    schedule 15.01.2014    source источник


Ответы (1)


Наконец нашел источник проблемы: панель инструментов отладки!

На самом деле он отправляет запрос ajax, что означает еще один MASTER_REQUEST..

Мое решение состоит в том, чтобы фильтровать контроллер с помощью белого/черного списка имен контроллеров.

ОБНОВЛЕНИЕ:

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

public function __construct()
{
    $this->classesExcluded = array("Symfony\Bundle\WebProfilerBundle\Controller\ProfilerController");
}


public function onKernelController(FilterControllerEvent $event)
{
    $controller = $event->getController();

    if (!is_array($controller) || HttpKernelInterface::MASTER_REQUEST != $event->getRequestType() || in_array(get_class($controller[0]), $this->classesExcluded)) {
        return;
    }
  // ...
}
person Bonswouar    schedule 15.01.2014
comment
Я закончил тем, что сделал это - strpos($event->getRequest()->attributes->get('_controller'), 'WebProfilerBundle') !== false Не уверен, насколько это разумно, но помогает. - person codekipple; 29.10.2014
comment
Иногда это Symfony\Bundle\FrameworkBundle\Controller\RedirectController, поэтому вы также можете исключить его. - person BentCoder; 06.01.2017
comment
В моем случае Symfony\Bundle\TwigBundle\Controller\ExceptionController вызывал второй раз. Я должен был исправить ошибку, и тогда все работало нормально. - person Strabek; 12.05.2017