从Symfony \ Component \ HttpFoundation \ Response获取标头

时间:2014-09-26 11:44:52

标签: php laravel

出于调试目的,我想在filters.php中记录响应对象中的所有头文件:

App::after(function($request, $response) {
  if(App::environment() !== 'dev') { return; }

  error_log(print_r($response->getHeadersPleaaase()));

$response通常是Illuminate\Http\JsonResponse,我找不到任何明显的方法来获取标题。

2 个答案:

答案 0 :(得分:1)

标题是公共财产:

error_log(print_r($response->headers));

答案 1 :(得分:0)

ini_set("log_errors", 1);
ini_set("error_log", __DIR__.'/../app/logs/prod.log');//ini_set("error_log", your path and file);
error_log( 'BEGIN===========>' );
error_log( $request );
error_log( $response );
error_log( '<========END' );

使用(Symfony2)

的一个例子

app.php

<?php

use Symfony\Component\ClassLoader\ApcClassLoader;
use Symfony\Component\HttpFoundation\Request;

$loader = require_once __DIR__.'/../app/bootstrap.php.cache';

// Use APC for autoloading to improve performance.
// Change 'sf2' to a unique prefix in order to prevent cache key conflicts
// with other applications also using APC.
/*
$apcLoader = new ApcClassLoader('sf2', $loader);
$loader->unregister();
$apcLoader->register(true);
*/

require_once __DIR__.'/../app/AppKernel.php';
//require_once __DIR__.'/../app/AppCache.php';

$kernel = new AppKernel('prod', false);
$kernel->loadClassCache();
//$kernel = new AppCache($kernel);

// When using the HttpCache, you need to call the method in your front controller instead of relying on the configuration parameter
//Request::enableHttpMethodParameterOverride();
$request = Request::createFromGlobals();
$response = $kernel->handle($request);

ini_set("log_errors", 1);
ini_set("error_log", __DIR__.'/../app/logs/prod.log');
error_log( 'BEGIN===========>' );
error_log( $request );
error_log( $response );
error_log( '<========END' );

$response->send();
$kernel->terminate($request, $response);