Symfony 2 FosUser:注册后进行身份验证

时间:2012-07-30 15:45:32

标签: symfony fosuserbundle

我正在使用FOSUserBundle和NnmMultiUserBundle。 当用户使用我的form_handler注册时,会创建用户实体,并且应该自动登录这个新用户。

我无法让自动登录工作。

我的控制器:

public function registerAction()
    {
        $discriminator = $this->container->get('nmn_user_discriminator');
        $discriminator->setClass('Travelyo\UserBundle\Entity\UserFrontend');
        $form = $discriminator->getRegistrationForm();

        //$form = $this->container->get('fos_user.registration.form');
        $formHandler = $this->container->get('fos_user.registration.form.handler');
        $confirmationEnabled = $this->container->getParameter('fos_user.registration.confirmation.enabled');

        $process = $formHandler->process($confirmationEnabled, array(User::ROLE_CUSTOMER));
        if ($process) {
            $user = $form->getData();

            if ($confirmationEnabled) {
                $this->container->get('session')->set('fos_user_send_confirmation_email/email', $user->getEmail());
                $route = 'fos_frontend_registration_check_email';
            } else {
                $this->authenticateUser($user);
                $route = 'fos_frontend_registration_confirmed';
            }

            $this->setFlash('fos_user_success', 'registration.flash.user_created');
            $url = $this->container->get('router')->generate($route);

            return new RedirectResponse($url);
        }

        return $this->container->get('templating')->renderResponse('TravelyoUserBundle:Registration:user_frontend.form.html.' . $this->getEngine(), array('form' => $form->createView(),));
    }

Athenticate方法:

protected function authenticateUser(UserInterface $user)
    {
        try {
            $this->container->get('fos_user.user_checker')->checkPostAuth($user);
        } catch (AccountStatusException $e) {
            // Don't authenticate locked, disabled or expired users
            return;
        }

        $providerKey = $this->container->getParameter('fos_user.firewall_name');
        $token = new UsernamePasswordToken($user, null, $providerKey, $user->getRoles());
        $this->container->get('security.context')->setToken($token);
    }

在调用athenticate后,控制器会重定向到ConfirmedAction,在那里它会尝试获取“登录”用户:

public function confirmedAction()
{
    $user = $this->container->get('security.context')->getToken()->getUser();
    if (!is_object($user) || !$user instanceof UserInterface) {
        throw new AccessDeniedException('This user does not have access to this section.');
    }

    return $this->container->get('templating')->renderResponse('FOSUserBundle:Registration:confirmed.html.'.$this->getEngine(), array(
        'user' => $user,
    ));
}

错误讯息:

  

致命错误:在第115行的/Data/Web/Local/travelyo/vendor/bundles/FOS/UserBundle/Controller/RegistrationController.php中的非对象上调用成员函数getUser()

如果我然后尝试使用登录表单登录,它工作正常(意味着用户的创建工作)。但我无法理解为什么无法从security.context中检索此令牌。

1 个答案:

答案 0 :(得分:2)

安全上下文(如symfony 2 doc中所述)不是跨防火墙共享的。

我的注册表格位于“公共防火墙”=> /注册。

在对用户进行身份验证时(在用户注册之后),将为public security.context保存令牌。

然后我被重定向到我的实际“帐户”firewall => / account,并且在security.context中找不到令牌,因为从未为该防火墙定义令牌。

为了解决这个问题,我只是简单地将注册过程移到了同一个防火墙下,现在就像魅力一样。

但我仍然认为应该可以为另一个security.context设置一个令牌,如果有人知道它可能有用。

谢谢!

相关问题