我在oauth和authlogic中连接loose end时遇到问题。 我正在运行rails 3.0.9,authlogic工作正常,我想添加twitter登录。
我遇到的问题是登录Twitter后重定向回调在twitter开发设置中定义的url。该应用重定向到顶级域名,同时将其附加到网址 user_sessions?组oauth_token = [t_o_k_e_n]
我在user_sessions_controller.rb中没有索引操作,所以我找不到动作索引的错误,但是我无法破译为什么我被重定向到这个网址?
我的user_sessions.rb
class UserSession < Authlogic::Session::Base
# def to_key
# new_record? ? nil : [ self.send(self.class.primary_key) ]
# end
#
# def persisted?
# false
# end
#
def self.oauth_consumer
OAuth::Consumer.new("asdasdsad", "asdasdasdas",
{ :site=>"http://twitter.com",
:authorize_url => "http://twitter.com/oauth/authenticate"})
end
end
我的user_sessions_controller.rb
class UserSessionsController < ApplicationController
# GET /user_sessions/new
# GET /user_sessions/new.xml
def new
@user_session = UserSession.new
end
# POST /user_sessions
# POST /user_sessions.xml
def create
@user_session = UserSession.new(params[:user_session])
@user_session.save do |result|
if result
flash[:notice] = "Login successful!"
redirect_back_or_default root_path
else
render :action => :new
end
end
# respond_to do |format|
# if @user_session.save
# format.html { redirect_to(root_path, :notice => 'User session was successfully created.') }
# format.xml { render :xml => @user_session, :status => :created, :location => @user_session }
# else
# format.html { render :action => "new" }
# format.xml { render :xml => @user_session.errors, :status => :unprocessable_entity }
# end
# end
end
# DELETE /user_sessions/1
# DELETE /user_sessions/1.xml
def destroy
@user_session = UserSession.find
@user_session.destroy
respond_to do |format|
format.html { redirect_to(root_path, :notice => 'Goodbye!') }
format.xml { head :ok }
end
end
end
我甚至尝试添加
:oauth_callback => "http://127.0.0.1:3000/"
到Consumer.new子句,但没有帮助。
最后,我的routes.rb看起来像这样:
resources :users, :user_sessions
match 'login' => 'user_sessions#new', :as => :login
match 'logout' => 'user_sessions#destroy', :as => :logout
任何人对如何排除故障或遇到类似问题都有任何想法?
答案 0 :(得分:0)
https://dev.twitter.com/sites/default/files/images_documentation/oauth_diagram.png非常明确地定义了您应该从Twitters Oauth提供商处发送和获取的内容。
你确定在步骤B中得到oauth_callback_confirmed
,如果是这样,你可能想联系Twitter,为什么他们验证你的oauth_callback
然后修改它