<?php
/*
* This file is part of the Symfony package.
*
* (c) Fabien Potencier <fabien@symfony.com>
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
namespace Symfony\Component\HttpKernel\EventListener;
use Symfony\Component\HttpKernel\Event\FilterResponseEvent;
use Symfony\Component\HttpKernel\HttpKernelInterface;
use Symfony\Component\HttpKernel\KernelEvents;
use Symfony\Component\EventDispatcher\EventSubscriberInterface;
/**
* ResponseListener fixes the Response headers based on the Request.
*
* @author Fabien Potencier <fabien@symfony.com>
*/
class ResponseListener implements EventSubscriberInterface {
private $charset;
public function __construct($charset) {
$this->charset = $charset;
}
/**
* Filters the Response.
*
* @param FilterResponseEvent $event A FilterResponseEvent instance
*/
public function onKernelResponse(FilterResponseEvent $event) {
if (HttpKernelInterface::MASTER_REQUEST !== $event
->getRequestType()) {
return;
}
$response = $event
->getResponse();
if (null === $response
->getCharset()) {
$response
->setCharset($this->charset);
}
$response
->prepare($event
->getRequest());
}
public static function getSubscribedEvents() {
return array(
KernelEvents::RESPONSE => 'onKernelResponse',
);
}
}
Name | Description |
---|---|
ResponseListener | ResponseListener fixes the Response headers based on the Request. |