7

TL;DR 在带有 Nginx / PHP-FPM 的 Linux 机器上出现错误,说明“无法启动会话,因为已经发送了标头。”。Apache 本地机器设置上未发生错误

所以在我的本地机器上,我的 Symfony2 应用程序运行良好。没有错误弹出。但是,一旦我部署到我们的 Linux 服务器,当我在 Controller 类中调用某个 Action 时,就会出现此错误

Failed to start the session because headers have already been sent. 

在我已经调用的索引操作中

$session = $this->getRequest()->getSession();

在同一个控制器类的另一个动作中,我再次调用它。当我尝试时弹出错误

$session->set('foo', $bar);

在我的 Twig 中,我通过一个表单和一个具有 formaction 属性的按钮来调用操作,如下所示

<form id='blahblah'>
    .... some fields here .....
    <button type='submit' formaction='{{path('2ndAction')}}'></a>
</form>

所以在我的本地机器上,运行 Apache 一切正常。Linux 服务器正在使用 Nginx 和 php-fpm,由于某种原因它崩溃了。我检查了 phpInfo() 并且会话自动启动设置为关闭。不确定这是否是 Nginx/php-fpm 问题,但我认为这可能是相关信息。

这是控制器声明、indexAction() 和我的 2ndAction()

use Symfony\Bundle\FrameworkBundle\Controller\Controller;
use Sensio\Bundle\FrameworkExtraBundle\Configuration\Route;
use Sensio\Bundle\FrameworkExtraBundle\Configuration\Template;
use Symfony\Component\HttpFoundation\Request;
use Symfony\Component\HttpFoundation\Response;
use Symfony\Component\HttpFoundation\Session\Session;    
use CBSi\Utils\HTTPUtils\CURLUtil;

class StartController extends Controller
{
    /**
     * @var  CurlUtil $curlUtil
     */
    private $curlUtil;

    /**
     * @var AccessControl $accessControl
     */

    private $accessControl;

    /*placeholder for request object*/
    private $requestHolder;


   /**
    * @Route("/path/for/action/one", name="start")
    * @Template()
    */


public function indexAction()
{
 $session = $this->getRequest()->getSession();
 $this->curlUtil = $this->get('curlUtil');
 $this->requestHolder= Request::createFromGlobals();

// Some logic is done here


return $this->render('ListEngagementBundle:Start:start.html.twig');

}

/**
 * @Route("/path/to/second/action", name="2ndAction")
 * @Template
 */
public function 2ndAction(){
    $session = $this->getRequest()->getSession();
    $this-> curlUtil = $this->get('curlUtil');
    $this->requestHolder= Request::createFromGlobals();

    //Some logic is done here to get the data for the session variable

       $bar= logic output

               $session->set('foo', $bar);

    return $this->redirect($this->generateUrl('start'));
}
}

如果您需要我可以提供的更多信息,我会:)

4

4 回答 4

8

所以我想通了。在我打电话的第二个动作中

$session->getRequest()->getSession(); 

我不得不将其更改为

$session = new Session();
$session->start();

去搞清楚。:P

于 2012-10-29T19:01:49.637 回答
6

我得到了同样的错误。但就我而言,我在 < ?php 标签之前的 AppKernel.php 中放置了一些空格。因此,如果其他人收到此错误,请检查在会话初始化之前加载的每个 .php 文件的第一行之前是否有一些空格或制表符。

于 2013-01-04T10:49:08.753 回答
2

当在某些预期$this->session->start(); echo语句的脚本中时,我会发生这种情况!希望这可以帮助其他人调试问题

于 2018-07-09T10:27:22.717 回答
0

每次我尝试使用 symfony 控制台更新我的数据库架构以及尝试使用 composer 安装新的依赖项时,我都会收到此错误消息:

[运行时异常]

Failed to start the session because headers have already been sent by "/var    
/www/html/pulsar283/src/MyService/Local/Brasil.php" at line 153.

所以,我去检查文件,在第 152 行我发现了一个“?>”(php 关闭标签)。

所以,我只是删除了 php 关闭标签,错误再也没有出现过!

于 2017-10-12T13:19:43.637 回答