使用 Google Oauth2 客户端访问 API 时 Rails 3.2.3 中出现 SSL 错误

2024-04-21

我对 OAuth2 相当陌生,我正在尝试使用 Omniauth 和 Google API 客户端通过 Google API 访问用户的 Blogger 帐户。我正在使用以下内容:

  • 轨道3.2.3
  • 红宝石 1.9.3
  • oauth2 (0.8.0)
  • 全方位认证 (1.1.1)
  • omn​​iauth-google-oauth2 (0.1.13)
  • 谷歌 API 客户端 (0.4.6)

当我第一次尝试使用 Google 凭据对用户进行身份验证时,收到以下错误:

SSL_connect returned=1 errno=0 state=SSLv3 read server certificate B: certificate verify failed

但是,当我在初始化程序中添加 CA 证书的特定路径时,错误消失了:

provider :google_oauth2, ENV['GOOGLE_APP_ID'], ENV['GOOGLE_SECRET'], {
  access_type: "offline",
  approval_prompt: "",
  scope: 'https://www.googleapis.com/auth/userinfo.email https://www.googleapis.com/auth/blogger',
  client_options: { ssl: { ca_file: cert_path } }
}

所以,现在我的用户可以使用他们的 Google 凭据登录,没有任何问题。我现在看到的问题是,当我尝试使用访问令牌(在用户身份验证期间从 Google 收到)访问 Blogger API 时,我再次收到 SSL 错误。这是我用来访问 API 的代码:

token = auth.first.oauth_token.access_token   # access token received during authentication

client = Google::APIClient.new
client.authorization.access_token = token
service = client.discovered_api('blogger', 'v3')
result = client.execute(
     :api_method => service.blog_list.list,
     :parameters => {},
     :headers => {'Content-Type' => 'application/json'})

该错误是在该行中生成的service = client.discovered_api('blogger', 'v3')

我已经把头撞在墙上有一段时间了,有人有什么想法吗?


休息了一下,又进行了一些谷歌搜索,又进行了更多的头脑碰撞,我发现了一个非常优雅的解决方案https://gist.github.com/867550 https://gist.github.com/867550。设置 SSL_CERT_FILE 环境变量并重新启动计算机修复了该问题。哦,是的,我是否忘记提及我正在 Windows 机器上进行开发?美好时光。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

使用 Google Oauth2 客户端访问 API 时 Rails 3.2.3 中出现 SSL 错误 的相关文章

随机推荐