4

次の認証ハンドラーがあります。

class LoginAuthSuccessHandler implements AuthenticationSuccessHandlerInterface, AuthenticationFailureHandlerInterface
{
    private $router;
    private $container;

    /**
    * Constructor
    * @param RouterInterface   $router
    */
    public function __construct(RouterInterface $router, $container)
    {
        $this->router = $router;
        $this->container = $container;
    }

    public function onAuthenticationSuccess(Request $request, TokenInterface $token)
    {
        if ($request->isXmlHttpRequest()) {
            $user =  $this->container->get('security.context')->getToken()->getUser();
            $result = array('success' => true, 'user' => $user);
            return new Response(json_encode($result));
        } else {
            $route = $this->router->generate('ShopiousMainBundle_profile');

            $referrer_url = $request->server->get('HTTP_REFERER');
            if (strstr($referrer_url, '/items/')) {
                 $route = $referrer_url;
            }

            return new RedirectResponse($route);
        }
    }

    public function onAuthenticationFailure(Request $request, AuthenticationException $exception)
    {
        if ($request->isXmlHttpRequest()) {
            $result = array('success' => false, 'message' => $exception->getMessage());
            return new Response(json_encode($result));
        } else {
            // Handle non XmlHttp request here
        }
    }
}

それはなぜですか:

$user =  $this->container->get('security.context')->getToken()->getUser();

null を返しますか? この時点で認証されたユーザーを取得するにはどうすればよいですか?

4

4 に答える 4

8

$tokenの代わりに、受け取った変数を引数として使用する必要があり$this->container->get('security.context')->getToken()ます。

$user = $token->getUser();
于 2013-08-30T16:14:44.480 に答える
0

私が見つけた唯一の方法は、entityManager を注入することでした。

calls:
    - [setEntityManager,[@doctrine.orm.entity_manager]]

リクエストからユーザー名を取得し、そのユーザー名を使用してユーザーをクエリします。

$userRepo->findByEmail($request->get('_username'));
于 2015-11-03T22:24:08.730 に答える