我有一个简单的 Rails 应用程序,我正在尝试使用 Netflix API 来访问我的一些订阅者信息,例如我的历史记录和队列。我的问题是,无论我做什么,Netflix 都不会使用我的oauth_callback
url,而是在我使用我的用户凭据授权应用程序后将我转发到 Netflix 站点。
这是向 Netflix API 发出请求的控制器代码
class ExportController < ApplicationController
def export
consumer = OAuth::Consumer.new( ENV['NETFLIX_KEY'],ENV['NETFLIX_SECRET'],
:site => "http://api.netflix.com",
:request_token_url => "http://api.netflix.com/oauth/request_token",
:access_token_url => "http://api.netflix.com/oauth/access_token",
:authorize_url => "https://api-user.netflix.com/oauth/login" )
request_token = consumer.get_request_token
session[:request_token]=request_token
session[:request_token_secret]=request_token.secret
url = request_token.authorize_url( :oauth_callback => "http://#{ENV['OAUTH_CALLBACK_DOMAIN']}/export_callback/", :oauth_consumer_key => ENV['NETFLIX_KEY'],
:application_name => ENV['APPLICATION_NAME'] )
redirect_to url
end
def export_callback
@request_token=OAuth::RequestToken.new(session[:request_token],session[:request_token_secret])
@access_token = @request_token.get_access_token(:oauth_verifier => params[:oauth_verifier])
end
end
控制器正确重定向到https://api-user.netflix.com/oauth/login
站点,并正确设置了所有参数。我得到了 Netflix 登录/授权应用页面。
但是,如果我查看此页面的来源,我会在表单中看到该oauth_callback
字段设置为oob
<input type="hidden" name="oauth_callback" value="oob"/>
我已经检查了几种不同的方法,并且我将oauth_callback
参数设置为与Netflix Authentication Walkthrough相同。事实上,当我完成演练并在他们的字段中输入我的回调 url 时,它实际上会重定向回我的 rails 应用程序。
那么,我的问题是,有人知道如何让 Netflix 尊重我的oauth_callback
领域吗?
编辑:
https://api-user.netflix.com/oauth/login?oauth_callback=http%3A%2F%2Fnetflix.dev%2Fexport_callback%2F&oauth_consumer_key=[REMOVED]&oauth_nonce=631831&oauth_timestamp=1321458391&application_name=[REMOVED]&oauth_token=[REMOVED]
您可以看到oauth_callback=http%3A%2F%2Fnetflix.dev%2Fexport_callback%2F
正在设置,这是到我的本地 rails 应用程序的路线。
编辑2:
我在 Mac OS X 10.6.8 上使用oauth (0.4.5)
and rails (3.1.0)
and 。ruby-1.9.2-p290 [ x86_64 ]