2012-07-30 4 views
1

NOSMultiUserBundle과 함께 FOSUserBundle을 사용하고 있습니다. 사용자가 my form_handler를 사용하여 등록 할 때 User 엔티티가 작성되고이 새 사용자에 자동으로 로그인해야합니다.Symfony 2 FosUser : 등록 후 인증

자동 로그인 작업을 수행하지 못했습니다.

내 컨트롤러 :

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); 
    } 

컨트롤러는 사용자 "로그인"얻을하려고 ConfirmedAction, 리디렉션 athenticate 호출 한 후

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, 
    )); 
} 

오류 메시지 : 다음 잘 작동 로그인 양식을 사용하여 로그인하려고하면

Fatal error: Call to a member function getUser() on a non-object in /Data/Web/Local/travelyo/vendor/bundles/FOS/UserBundle/Controller/RegistrationController.php on line 115

(사용자의 생성이 작동하고 있음을 의미). 하지만 왜이 토큰을 security.context에서 검색 할 수 없는지 이해할 수 없습니다.

+0

무엇을 의미합니까? – LEM01

+1

[이전 질문] (http://stackoverflow.com/users/1006066/lem01?tab=questions)에 대한 대답을 수락하십시오. –

+0

아 .. 사실 ... 저는 종종 내 메인 포스트 또는 원래의 질문을 편집하여 내가 그렇게 할거야 ... Thx! – LEM01

답변

2

보안 컨텍스트는 방화벽을 통해 공유되지 않습니다 (symfony 2 문서에 설명되어 있음).

내 등록 양식이 "public firewall"=>/register에 있습니다.

사용자가 등록 된 직후에 사용자를 인증하면 토큰이 public security.context에 저장됩니다.

그런 다음 실제 "계정"방화벽 =>/account로 리디렉션되었으며 토큰이 해당 방화벽에 대해 정의 된 적이 없어서 security.context에 토큰이 발견되지 않았습니다.

나는 그것을 해결하기 위해 단순히 같은 방화벽 아래에서 등록 프로세스를 옮겼습니다. 이제는 매력처럼 작동합니다.

하지만 다른 사람이 유용 할 수있는 방법을 알고 있다면 다른 security.context에 대한 토큰을 설정할 수 있어야한다고 생각합니다.

감사합니다.