FOSOAuthServerBundle - 如何在控制器中获取用户


FOSOAuthServerBundle - How to get User in a controller

我在我的应用程序中实现了FOSOAuthServerBundle,为移动应用程序提供了一个API。它似乎有效,用户得到TokenRefreshToken但是如果我使控制器需要始终返回null的用户对象。也无法控制权限,该权限仅IS_AUTHENTICATED_ANONIMOUSLY

例:

public function showUserAction(){
   $user = $this->getUser()
   //$user = null
   $auth = $this->get('security.context')->isGranted('IS_AUTHENTICATED_FULLY')
   //$auth = false
}

如何使用这种类型的身份验证在控制器中获取用户对象?

根据您的

评论,您创建了具有不同grant_types的客户端。

注意:如果在身份验证期间使用 grant_type=client_credentials,则没有可用的用户,因为您没有指定用于生成令牌的确切用户/密码。在grant_type=密码的情况下,您传递用户名和密码,在这种情况下,令牌链接到用户。希望这是有道理的。

试试这个:

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