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에서 검색 할 수 없는지 이해할 수 없습니다.
무엇을 의미합니까? – LEM01
[이전 질문] (http://stackoverflow.com/users/1006066/lem01?tab=questions)에 대한 대답을 수락하십시오. –
아 .. 사실 ... 저는 종종 내 메인 포스트 또는 원래의 질문을 편집하여 내가 그렇게 할거야 ... Thx! – LEM01