我在我的应用程序中实现了FOSOAuthServerBundle,为移动应用程序提供了一个API。它似乎有效,用户得到Token
和RefreshToken
但是如果我使控制器需要始终返回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();