3

我已经编写了自己的ExceptionController并希望将调试令牌作为输出的一部分注入。
我查看了WebProfilerToolbarListener,这与我的情况类似,但似乎异常/错误响应有另一个生命周期。

ProfilerCollector总是在我的侦听器之后调用,它位于响应事件上。
我的 Listener 需要在ProfilerCollector之后调用。

我怎样才能实现它?

在此处输入图像描述

4

2 回答 2

1

我尝试使用不同的优先级,但似乎您需要完全清除缓存。在开发模式下重新加载页面是不够的。

在将优先级更改为-150后,如下所示。

profiler_link_listener:
    class:Nerdhive\TheNetwork\TwigBundle\EventListener\ProfilerLinkListener
    priority: -150
    tags:
        - { name: kernel.event_listener, event: kernel.response, method: onKernelResponse }

在此处输入图像描述

您可以检索调试令牌,如下所示:

public function onKernelResponse(FilterResponseEvent $event)
{
    $response = $event->getResponse();
    $token = $response->headers->get('X-Debug-Token');
    // Do here your stuff
}

一般来说-129也应该适用于WebDebugToolbarListener文档

public static function getSubscribedEvents()
{
    return array(
        KernelEvents::RESPONSE => array('onKernelResponse', -128),
    );
}
于 2015-02-15T21:58:34.760 回答
0

您应该使用侦听器的优先级:我猜您的RequestDataCollector侦听器具有priority: 0,您应该将其扩大。

或者换句话说,让你的听众优先-1

有关侦听器优先级的更多详细信息

于 2015-02-13T07:43:45.250 回答