LexikJWTAuthenticationBundle Декодирование токена в контроллере - PullRequest
0 голосов
/ 11 июня 2018

Я пытаюсь найти его в документации, если есть способ декодировать токен в идентификатор пользователя.Предоставляет ли этот пакет такую ​​опцию / услугу?Спасибо

1 Ответ

0 голосов
/ 12 июня 2018

Таким образом, решение, которое сработало, заключалось в создании нового правила брандмауэра

    auto_login:
        pattern: ^/auto_login
        anonymous: true
        stateless: true
        lexik_jwt:
            query_parameter:
                enabled: true
                name:    bearer

Теперь я могу передать токен как запрос get

/auto_login/redirect_to_some_url?bearer=eyJhbGciOiJSUzI1...

и в контроллере для маршрута "/auto_login "Я создаю сеанс для пользователя, если токен хорош, и у меня автоматический вход, выглядит и работает хорошо.

/**
 * @Route("/auto_login", name="auto_login")
 * @Route("/auto_login/{redirect}")
 */
public function autoLoginAction(Request $request, $redirect = null)
{
    $current_user_id = $this->getUser()->getId();
    if ($redirect && $current_user_id) {

        $user = $this->getDoctrine()->getManager()->getRepository('AppBundle:User')->find($current_user_id);

        $sf_token = new UsernamePasswordToken($user, null, 'main', $user->getRoles());
        $this->get('security.token_storage')->setToken($sf_token);
        $this->get('session')->set('_security_main', serialize($sf_token));

        $event = new InteractiveLoginEvent($request, $sf_token);
        $this->get('event_dispatcher')->dispatch('security.interactive_login', $event);

        return $this->redirectToRoute($redirect);
    } else {
        return $this->redirectToRoute('login');
    }
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...