【问题标题】:Google Oauth not getting refresh tokenGoogle Oauth 没有获得刷新令牌
【发布时间】:2015-07-03 17:30:19
【问题描述】:

我正在尝试获取刷新令牌。 我在谷歌文档中读到了它。 现在,我正在离线使用 accesstype 并且还使用approval_prompt:“force” 但我没有得到刷新令牌作为回应。 我不明白我做错了什么。

我有以下 html 代码:

<input type="submit" class="btn btn-info" value="Google" onclick="authorizeWithGoogle()" />

Javascript 代码:

 var cid = 'XXXXX';
 var apik = 'XXXXX';
 var scopes = 'https://www.google.com/m8/feeds';

 function authorizeWithGoogle() {
     gapi.client.setApiKey(apik); 
     gapi.auth.authorize({ client_id: cid, scope: scopes,  accesstype: "offline"   ,approval_prompt: "force"}, handleAuthResult);
 }

 function handleAuthResult(authResult) {
     delete authResult['g-oauth-window'];
 if (authResult && !authResult.error) {
    console.log(JSON.stringify(authResult));      
 }
}

你能帮帮我吗?

【问题讨论】:

标签: javascript google-oauth


【解决方案1】:

您不希望请求刷新令牌,因为这会否定 OAuth 的安全性。刷新令牌应该只被请求/存储在服务器上。在继续之前,您可能想退后一步,回顾一下您对 OAuth 的理解。尝试在不了解 OAuth 的情况下实现 OAuth 是一个皮塔。

对于浏览器客户端,只要您需要新的访问令牌(例如,大约每小时一次),您就应该简单地继续调用 gapi.auth.authorize。第一次通话后,您可以设置immediate=true,这将抑制任何用户界面。

【讨论】:

  • 感谢您的回复。我再次阅读,是的,我必须从服务器请求中获取刷新令牌。道歉。
【解决方案2】:

首先,你打错了,它缺少下划线:它是access_type,而不是accesstype

然后,除了通过access_typeapproval_prompt,您还需要确保您的测试用户删除了您的应用程序的授权。使用您的测试帐户(而不是您的应用帐户)登录 Google,然后转到 Account Permissions 并从列表中删除您的应用。

【讨论】:

  • 如果我更改为 access_type 它会给我错误。 access_type '离线'不允许 response_type 令牌
  • 您需要在请求授权码时传递access_typeapproval_prompt,而不是在令牌请求期间(即当response_typecode 时)。
猜你喜欢
  • 1970-01-01
  • 2015-06-27
  • 1970-01-01
  • 2014-05-11
  • 2021-02-11
  • 1970-01-01
  • 2021-11-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多