OAuth与authlogic和twitter。不正确重定向

时间:2011-09-07 00:46:14

标签: ruby-on-rails oauth authlogic-oauth

我在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

任何人对如何排除故障或遇到类似问题都有任何想法?

1 个答案:

答案 0 :(得分:0)

https://dev.twitter.com/sites/default/files/images_documentation/oauth_diagram.png非常明确地定义了您应该从Twitters Oauth提供商处发送和获取的内容。

你确定在步骤B中得到oauth_callback_confirmed,如果是这样,你可能想联系Twitter,为什么他们验证你的oauth_callback然后修改它