Rails EOF使用HTTP.get_response检索Facebook访问令牌时出错

时间:2011-02-22 18:20:18

标签: ruby-on-rails ruby facebook oauth

我尝试在我的网站上实现Login with Facebook功能,并试图从Facebook获取访问令牌。这是我的代码:

if params[:error_reason] == "user_denied" then
  flash[:error] = "To login with Facebook, you must click 'Allow' to let the site access your information"
  redirect_to :login
elsif params[:code] then
  token_uri = URI.parse("https://graph.facebook.com/oauth/access_token?client_id=****************&redirect_uri=http://localhost:3000/auth/fblogin&client_secret=***************&code="+URI.escape(params[:code]))
  response = Net::HTTP.get_response(token_uri)
  session[:response] = response
  data = ActiveSupport::JSON.decode(response)
  access_token = data[:access_token]
  flash[:error] = access_token
  redirect_to :register
end

这是在fblogin控制器函数内部,它是获取授权代码(params[:code])的初始重定向的目标。

但是当我遇到这个问题时,我收到以下错误:

EOFError in AuthController#fblogin

Net::HTTP.get_response(token_uri)行上

。我到处搜索过,找不到任何表明这意味着什么的东西。它可能是Facebook在访问令牌中使用的模糊字符吗?我完全失去了!

1 个答案:

答案 0 :(得分:10)

您收到EOFError,因为您尝试使用仅适用于https的代码连接到http网址。有关基础知识,请参阅this Net::HTTP Cheat Sheet上标题为“SSL / HTTPS请求”的部分。

但是,我建议使用第三方库为您管理,例如OAuth2使用Facebook的OAuth2 API,您可以在其中编写如下代码:

def client
  OAuth2::Client.new('app_id', 'app_secret', :site => 'https://graph.facebook.com')
end

# in your callback code:
access_token = client.web_server.get_access_token(params[:code], :redirect_uri => 'http://localhost:3000/auth/fblogin')
user = JSON.parse(access_token.get('/me'))

如果您真的想自己提出请求,可以查看像Faraday这样的库来为您执行HTTPS请求。