Ответ 1
Текущие версии Symfony (Symfony 4, Symfony> = 3.2)
Поскольку Symfony> = 3.2, вы можете просто ожидать, что реализация UserInterface
внедрена непосредственно в действие вашего контроллера. Затем вы можете вызвать getId()
для получения идентификатора пользователя:
class DefaultController extends Controller
{
// when the user is mandatory (e.g. behind a firewall)
public function fooAction(UserInterface $user)
{
$userId = $user->getId();
}
// when the user is optional (e.g. can be anonymous)
public function barAction(UserInterface $user = null)
{
$userId = null !== $user ? $user->getId() : null;
}
}
Вы все еще можете использовать хранилище токенов безопасности, как и во всех версиях Symfony начиная с версии 2.6. Например, в вашем контроллере:
$user = $this->get('security.token_storage')->getToken()->getUser();
Обратите внимание, что ярлык Controller::getUser()
упомянутый в следующей части этого ответа, больше не рекомендуется.
Устаревшие версии Symfony
Самым простым способом доступа к пользователю было расширение базового контроллера и использование ярлыка getUser()
:
$user = $this->getUser();
Начиная с Symfony 2.6 вы можете получить пользователя из хранилища токенов безопасности:
$user = $this->get('security.token_storage')->getToken()->getUser();
До Symfony 2.6 токен был доступен из службы контекста безопасности:
$user = $this->get('security.context')->getToken()->getUser();
Обратите внимание, что служба контекста безопасности устарела в Symfony 2 и удалена в Symfony 3.0.