我尝试在我的网站上实现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在访问令牌中使用的模糊字符吗?我完全失去了!
答案 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请求。