【发布时间】:2016-07-10 15:29:43
【问题描述】:
情况
我有一个简单的 android 应用程序,用户使用 REST api 从 Google Fusion Tables 获取数据。为此,我使用 OAuth 2 授权来获取访问令牌和刷新令牌。我的应用程序中有网络视图,它将显示登录屏幕和同意屏幕。我计划从 Web 视图中获取访问令牌并将其用于进一步的 API 调用。我正在使用retrofit 来执行我的http 调用。我使用以下查询参数,
"client_id" = CLIENTID
"client_secret" = SECRET
"code" = 4/XXXXXXXXXX //Code got from redirect url
"grant_type" = "authorization_code"
"access_type" = "offline"
"approval_prompt" = "force"
"redirect_uri" = REDIRECT_URL
到目前为止一切顺利。但是当我使用上述查询参数执行发布请求时,我得到以下响应,
{
"access_token": "ya29.XXXXXXXXXXXXXX",
"token_type": "Bearer",
"expires_in": 3599,
"id_token": "XXXXXXXXXX"
}
问题
刷新令牌在哪里?我需要刷新令牌,因为稍后我无法使用访问令牌通过应用程序进行 API 调用,而且我不希望用户每次都获取访问令牌。
我的尝试
我已经按照this 帖子中的说明进行操作,并尝试从设置中撤消对应用程序的权限。我也尝试过使用不同的谷歌帐户以防出现一些权限问题,但仍然没有运气。我也尝试过删除查询参数“approval_prompt”和“grant_type”,但这也没有帮助。
【问题讨论】:
标签: android oauth oauth-2.0 google-api access-token