无法启动会话:已由 PHP 启动(设置了 _SESSION)。500 内部服务器错误 - 运行时异常

2022-08-30 21:39:18

我正在尝试为我的用户管理捆绑实现一个简单的登录页面,我是通过表单构建器创建表单的新手。我的捆绑包中只有3个函数,其中有一个新会话,它在不同的路由中被调用,即使我删除了其他2个,我仍然收到相同的错误。这是我的代码:

    <?php

    namespace Acme\UserManagementBundle\Controller;

    use Symfony\Bundle\FrameworkBundle\Controller\Controller;
    use Symfony\Component\HttpFoundation\Request;
    use Symfony\Component\HttpFoundation\Session\Session;
    use Acme\UserManagementBundle\Entity\Users;
    use Acme\UserManagementBundle\Form\SigninType;

    class DefaultController extends Controller
    {
        public function indexAction()
        {
            $session = new Session();
            $users = new Users();
            $form = $this->createForm(new SigninType(), $users);

            if ($session->has('token'))
            {
                 return $this->render('AcmeUserManagementBundle:Default:home.html.twig', array('token' => $session->get('token')));
            }
            if (!($session->has('alert')))
            {
                $session->set('alert', 'Welcome');
                return $this->render('AcmeUserManagementBundle:Default:index.html.twig', array('form' => $form->createView(), 'alert' => 'Welcome!'));   
            }
            else
            {
                $alert = $session->get('alert');
                $session->clear();
                return $this->render('AcmeUserManagementBundle:Default:index.html.twig', array('form' => $form->createView() ,'alert' => $alert));
            }
        }

        public function logoutAction()
        {
            $session = new Session();
            $session->invalidate();
            return $this->render('AcmeUserManagementBundle:Default:index.html.twig');
        }

         public function signupAction()
        {
            return $this->render('AcmeUserManagementBundle:Default:signup.html.twig');
        }
        public function LoginAction(Request $request)
        {
            $session = new Session();
            if ($request->getmethod()=='POST' || $session->get('token') != ""){
                $user = $request->get('user');
                $password = $request->get('password');
                $em = $this->getDoctrine()->getManager();
                $repository = $em->getRepository('AcmeUserManagementBundle:Users');
                $username = $repository->findOneBy(array('username'=>$user,'password'=>$password));
                    if (!$session->get('token') && $username)
                    {
                       $token = $this->get('token_generator')->getToken();
                       $session->set('token', $token, 'user', $username);
                    } else {
                        $session->set('alert', 'Invalid Username and/or Password!');
                        return $this->redirect($this->generateUrl('homepage'));
                    }
                    return $this->redirect($this->generateUrl('homepage'));
            } else {
                return $this->redirect($this->generateUrl('homepage'));
            }   
        }
    }

当我试图在我的函数中实现一个表单构建器接口时,我突然遇到了这个与从html到html的正常创建,我根本没有遇到任何问题。我的代码有问题吗?因为我通过HTML尝试了这个登录代码,并将其转换为Symfony的formbuilderinterface组件。


答案 1

默认情况下,Symfony2 会自动为您启动会话。

不需要$session = new Session();

试试这个,

  public function indexAction(Request $request)
 {
    $session = $request->getSession();

编号: http://symfony.com/doc/current/book/controller.html#managing-the-session


答案 2

你做错了!

我一直在浪费一些时间来寻找该问题的解决方案,并最终在函数Action()中做同样的事情(使用请求$request)将会话变量发送到模板。

然而,所有这些都是错误的。TWIG能够直接访问所有会话变量,您无需在TWIG render()中传递任何变量。

要回答原始问题,您应该保留 indexAction() 的默认行为,不带参数,并从 TWIG 渲染调用中删除“ array('token' => $session->get('token')) ”。

唯一需要知道的是,您可以直接在模板中调用会话变量“token”,使用:{{ app.session.get('token') }}

让魔法成为!就是这么简单!


推荐