3

我正在尝试使用 Google 的 API 注册用户并将其登录到我的 rails webapp。我一直在使用身份验证,但是在获得授权码后我遇到了这个错误。

这是我正在尝试做的事情:

path = Rails.root.to_s + PATH_TO_JSON_FILENAME_FROM_GOOGLE_API

client_secrets = Google::APIClient::ClientSecrets.load(path)

auth_client = client_secrets.to_authorization

auth_client.update!(
  :scope => 'https://www.googleapis.com/auth/drive.metadata.readonly',
  :redirect_uri => REDIRECT_URI

)

auth_client.code = ACCESS_CODE_RETURNED_BY_GOOGLE_WHEN_USER_LOGS_IN

auth_client.fetch_access_token!

几个问题:

  1. 我真正想要的只是用户名和他们的电子邮件地址。我不清楚正确的价值:scope应该是什么。
  2. 对于redirect_uri我将其设置为我的 Google API 控制台中的重定向 uri 之一。类似的东西http://localhost:3000/auth/callback。尽管如此,我还是收到了以下 json 响应:

    {“错误”:“redirect_uri_mismatch”}

关于我在这里可能做错了什么的想法?

4

2 回答 2

2

终于想通了。我需要将 设置redirect_uripostmessage,因为这就是我最初请求授权码的方式。这是我的完整解决方案:

我使用以下内容加载 Google 身份验证库:

function start() {
  gapi.load('auth2', function() {
    auth2 = gapi.auth2.init({
      client_id: 'MY_CLIENT_ID',
    });
  });
};

我创建了一个 HTML 按钮,单击该按钮会调用以下函数:

function(e){
    e.preventDefault();    
    auth2.grantOfflineAccess({'redirect_uri': 'postmessage'}).then(this.signInCallback);
},

现在该signInCallback功能只是记录我的授权代码,因此我可以测试我正在编写的 ruby​​ 服务器代码:

function(authResult) {
    console.log(authResult.code);
}

这是我的 ruby​​ 文件的样子:

client = Google::APIClient.new
client.authorization.client_id = MY_CLIENT_ID
client.authorization.client_secret = MY_CLIENT_SECRET
client.authorization.redirect_uri = "postmessage"
client.authorization.code = CODE_THAT_WAS_LOGGED_TO_CONSOLE
client.authorization.fetch_access_token!

更多信息:您必须使用 'postmessage' 调用grantOfflineAccess。我尝试从我的开发人员控制台中输入一个实际的重定向 uri,但它不喜欢这样(有关更多信息,请参阅这个SO 问题)。我发现如果你这样做,那么当你尝试用授权码交换访问令牌时,你需要在服务器端做同样的事情。

于 2015-08-09T20:59:04.377 回答
0

重定向 URI 不匹配错误肯定意味着重定向 URI 与注册的不同。额外确保 URI 是相同的。

于 2015-08-08T05:00:18.450 回答