2011-11-03 66 views
1

我試圖讓我的應用程序使用Rails,Authlogic和Omniauth來登錄Facebook登錄。儘可能精確地遵循http://railscasts.com/episodes/235-omniauth-part-1的第一步。Rails,Omniauth,Authlogic和Facebook - 第一步

我:

  • 加入omniauth寶石,運行bundle install
  • 創建了一個新的身份驗證腳手架,其字段爲user_id,provideruid
  • 添加的路線:match '/auth/:provider/callback' => 'authentications#create'
  • 添加到配置/初始化/ omniauth.rb:

    Rails.application.config.middleware.use OmniAuth::Builder do 
        provider :facebook, '20...my_app_id', 'bc...my_app_secret' 
    end 
    

然後,服務器無法重新啓動:

/Users/san/.rvm/gems/ruby-1.9.2-p0/gems/aws-s3-0.6.2/lib/aws/s3/extensions.rb:206: 
    in 'const_missing_from_s3_library': uninitialized constant 
    OmniAuth::Strategies::Facebook (NameError) 
    from /Users/san/.rvm/gems/ruby-1.9.2-p0/gems/rake-0.9.2/lib/rake/ext/module.rb:36:in 'const_missing' 
    from /Users/san/.rvm/gems/ruby-1.9.2-p0/gems/omniauth-1.0.0/lib/omniauth/builder.rb:22:in 'const_get' 
    from /Users/san/.rvm/gems/ruby-1.9.2-p0/gems/omniauth-1.0.0/lib/omniauth/builder.rb:22:in 'provider' 
    from /Users/san/Documents/sanj/myapp/config/initializers/omniauth.rb:2:in 'block in <top (required)>' 
    from /Users/san/.rvm/gems/ruby-1.9.2-p0/gems/rack-1.2.3/lib/rack/builder.rb:46:in 'instance_eval' 
    from /Users/san/.rvm/gems/ruby-1.9.2-p0/gems/rack-1.2.3/lib/rack/builder.rb:46:in 'initialize' 
    from /Users/san/.rvm/gems/ruby-1.9.2-p0/gems/omniauth-1.0.0/lib/omniauth/builder.rb:7:in 'initialize' 
    from /Users/san/.rvm/gems/ruby-1.9.2-p0/gems/actionpack-3.0.10/lib/action_dispatch/middleware/stack.rb:33:in 'new' 
    from /Users/san/.rvm/gems/ruby-1.9.2-p0/gems/actionpack-3.0.10/lib/action_dispatch/middleware/stack.rb:33:in 'build' 
    from /Users/san/.rvm/gems/ruby-1.9.2-p0/gems/actionpack-3.0.10/lib/action_dispatch/middleware/stack.rb:79:in 'block in build' 
    from /Users/san/.rvm/gems/ruby-1.9.2-p0/gems/actionpack-3.0.10/lib/action_dispatch/middleware/stack.rb:79:in 'each' 
    from /Users/san/.rvm/gems/ruby-1.9.2-p0/gems/actionpack-3.0.10/lib/action_dispatch/middleware/stack.rb:79:in 'inject' 
    from /Users/san/.rvm/gems/ruby-1.9.2-p0/gems/actionpack-3.0.10/lib/action_dispatch/middleware/stack.rb:79:in 'build' 
    from /Users/san/.rvm/gems/ruby-1.9.2-p0/gems/railties-3.0.10/lib/rails/application.rb:162:in 'app' 
    from /Users/san/.rvm/gems/ruby-1.9.2-p0/gems/railties-3.0.10/lib/rails/application/finisher.rb:35:in 'block in <module:Finisher>' 
    from /Users/san/.rvm/gems/ruby-1.9.2-p0/gems/railties-3.0.10/lib/rails/initializable.rb:25:in 'instance_exec' 
    from /Users/san/.rvm/gems/ruby-1.9.2-p0/gems/railties-3.0.10/lib/rails/initializable.rb:25:in 'run' 
    from /Users/san/.rvm/gems/ruby-1.9.2-p0/gems/railties-3.0.10/lib/rails/initializable.rb:50:in 'block in run_initializers' 
    from /Users/san/.rvm/gems/ruby-1.9.2-p0/gems/railties-3.0.10/lib/rails/initializable.rb:49:in 'each' 
    from /Users/san/.rvm/gems/ruby-1.9.2-p0/gems/railties-3.0.10/lib/rails/initializable.rb:49:in 'run_initializers' 
    from /Users/san/.rvm/gems/ruby-1.9.2-p0/gems/railties-3.0.10/lib/rails/application.rb:134:in 'initialize!' 
    from /Users/san/.rvm/gems/ruby-1.9.2-p0/gems/railties-3.0.10/lib/rails/application.rb:77:in 'method_missing' 
    from /Users/san/Documents/sanj/myapp/config/environment.rb:5:in '<top (required)>' 
    from /Users/san/Documents/sanj/myapp/config.ru:3:in 'block in <main>' 
    from /Users/san/.rvm/gems/ruby-1.9.2-p0/gems/rack-1.2.3/lib/rack/builder.rb:46:in 'instance_eval' 
    from /Users/san/.rvm/gems/ruby-1.9.2-p0/gems/rack-1.2.3/lib/rack/builder.rb:46:in 'initialize' 
    from /Users/san/Documents/sanj/myapp/config.ru:1:in 'new' 
    from /Users/san/Documents/sanj/myapp/config.ru:1:in '<main>' 
    from /Users/san/.rvm/gems/ruby-1.9.2-p0/gems/rack-1.2.3/lib/rack/builder.rb:35:in 'eval' 
    from /Users/san/.rvm/gems/ruby-1.9.2-p0/gems/rack-1.2.3/lib/rack/builder.rb:35:in 'parse_file' 
    from /Users/san/.rvm/gems/ruby-1.9.2-p0/gems/rack-1.2.3/lib/rack/server.rb:162:in 'app' 
    from /Users/san/.rvm/gems/ruby-1.9.2-p0/gems/rack-1.2.3/lib/rack/server.rb:253:in 'wrapped_app' 
    from /Users/san/.rvm/gems/ruby-1.9.2-p0/gems/rack-1.2.3/lib/rack/server.rb:204:in 'start' 
    from /Users/san/.rvm/gems/ruby-1.9.2-p0/gems/railties-3.0.10/lib/rails/commands/server.rb:65:in 'start' 
    from /Users/san/.rvm/gems/ruby-1.9.2-p0/gems/railties-3.0.10/lib/rails/commands.rb:30:in 'block in <top (required)>' 
    from /Users/san/.rvm/gems/ruby-1.9.2-p0/gems/railties-3.0.10/lib/rails/commands.rb:27:in 'tap' 
    from /Users/san/.rvm/gems/ruby-1.9.2-p0/gems/railties-3.0.10/lib/rails/commands.rb:27:in '<top (required)>' 
    from script/rails:7:in 'require' 
    from script/rails:7:in '<main>' 

回答

2

的omniauth創業板剛剛碰到1.0版,截至昨天(http://intridea.com/2011/11/2/omniauth-1-0),並且對如何使用寶石有一些改變沒有包含在railscast中。

我發現我的這個頁面上的解決方案:https://github.com/intridea/omniauth/wiki/OmniAuth-1.0

最大的不同的是,每一種策略現在包含它自己的寶石之內,所以對於Facebook,你會改變你的寶石文件中的行,目前寫着「創業板'omniauth'「改爲」gem'omniauth-facebook'「。

我不必更改任何其他代碼,而且您可能必須運行「軟件包更新」才能讓所有內容都點擊。

+0

不適合我... 2012年9月。 –

5

我不得不在我的config/development.rb文件中做'require'omniauth「'或'require」omniauth-facebook「'。

+0

謝謝噸... – Rahul

1

我只是碰到了這個問題,這是什麼毛病我:

你不能在發展列表您Facebook的OAuth寶石在你的寶石文件。 Heroku只讀取生產版本,因此將其移出開發列表。