1

我正在尝试使用设计和omniauth 向google oauth2 进行身份验证。我按照omniauth文档中的规定虔诚地设置了回调,甚至使用了相同的确切代码。https://github.com/plataformatec/devise/wiki/OmniAuth:-概述

我将代码上传到 github:https ://github.com/kiranjulapalli/devisetest

我被重定向到登录,当我选择我的帐户时,我再次被重定向到登录页面。我在这里想念什么?

这是日志:

Started GET "/users/auth/google_oauth2/callback?state=3baa394efe9c586b30fgfc05b1f618af04b7728d0d75c3c1&code=4/HxV9O
37jKYgxg10EWDntdfewZTz3.4kqevOMEweMTshQV0ieZDArQUdYefAI" for 127.0.0.1 at 2013-04-15 16:36:01 -0400
Processing by Users::OmniauthCallbacksController#google_oauth2 as HTML
  Parameters: {"state"=>"3baa394efe9c586b30fgfc05b1f618af04b7728d0d75c3c1", "code"=>"4/HxV9O
37jKYgxg10EWDntdfewZTz3.4kqevOMEweMTshQV0ieZDArQUdYefAI"}
  MOPED: 127.0.0.1:27017 COMMAND      database=admin command={:ismaster=>1} (2.0001ms)
  MOPED: 127.0.0.1:27017 QUERY        database=devisetest_development collection=users selector={"$query"=>{"email"
=>"myemailaddress@gmail.com"}, "$orderby"=>{:_id=>1}} flags=[:slave_ok] limit=-1 skip=0 batch_size=nil fields=nil
(0.9999ms)
Completed 401 Unauthorized in 24ms
#custom log statements
logger::Find if this user exists
logger::Return user
logger:Got call back
logger:User persisted

我的 routes.rb 文件:

Devisetest::Application.routes.draw do
  devise_for :users, :controllers => { :omniauth_callbacks => "users/omniauth_callbacks" }
  resources :users
  root :to => 'home#index'
end
4

1 回答 1

3

您要求您的用户在登录之前通过电子邮件进行确认。(从 :confirmable 参数到您的 user.rb 中设计)

您可以通过 rails 控制台删除 :confirmable 或手动为 user.confirmed_at 分配一个值(例如 Time.now)。

您还应该在布局中的某处显示 flash[:notice],您会看到:“已成功通过 Google 帐户进行身份验证。您必须在继续之前确认您的帐户。”

它看起来像: 总是得到 401 Unauthorized with new install of Rails + Devise 是一个类似的问题。

于 2013-04-16T01:31:23.767 回答