1

FOSUserBundle を NnmMultiUserBundle と一緒に使用しています。ユーザーが form_handler を使用して登録すると、User エンティティが作成され、この新しいユーザーに自動的にログインする必要があります。

自動ログインを機能させることができませんでした。

私のコントローラー:

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

認証方法:

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 から取得できない理由がわかりません。

4

1 に答える 1

2

セキュリティ コンテキストは (symfony 2 doc で説明されているように) ファイアウォール間で共有されません。

私の登録フォームは「パブリックファイアウォール」=> /register にありました。

ユーザーを認証するとき (ユーザーが登録された直後)、トークンは public security.context 用に保存されます。

次に、実際の「アカウント」ファイアウォール => /account にリダイレクトされましたが、そのファイアウォールに対してトークンが定義されていなかったため、security.context にトークンが見つかりませんでした。

それを解決するために、登録プロセスを同じファイアウォールの下に移動しただけで、今では魅力的に機能します。

しかし、誰かがそれがどのように役立つかを知っていれば、別の security.context のトークンを設定できるはずだと思います。

ありがとう!

于 2012-08-02T13:23:35.527 に答える