2

我正在尝试实现一个仅支持通过 Google 帐户登录以访问分析数据的登录系统。

我无法让它与异常一起工作

undefined method `new_session_path' for #<Users::OmniauthCallbacksController:0x8f588b0>

我正在使用omniauthomniauth-google-oauth2策略。

这是宝石文件

source 'https://rubygems.org'

gem 'rails', '3.2.3'

# Bundle edge Rails instead:
# gem 'rails', :git => 'git://github.com/rails/rails.git'

gem 'mysql2'
gem 'haml'
gem 'haml-rails'
gem 'omniauth'
gem 'omniauth-google-oauth2'
gem 'devise'

# Gems used only for assets and not required
# in production environments by default.
group :assets do
  gem 'sass-rails',   '~> 3.2.3'
  gem 'coffee-rails', '~> 3.2.1'

  # See https://github.com/sstephenson/execjs#readme for more supported runtimes
  gem 'therubyracer', :platform => :ruby

  gem 'uglifier', '>= 1.0.3'
end

gem 'jquery-rails'

# To use ActiveModel has_secure_password
# gem 'bcrypt-ruby', '~> 3.0.0'

# To use Jbuilder templates for JSON
# gem 'jbuilder'

# Use unicorn as the app server
# gem 'unicorn'

# Deploy with Capistrano
# gem 'capistrano'

# To use debugger
# gem 'ruby-debug19', :require => 'ruby-debug'

group :test do
  gem 'capybara'
  gem 'database_cleaner'
  gem 'rspec-rails'
  gem 'cucumber-rails'
  gem 'factory_girl_rails'
end

这是config/routes.rb

TestApp::Application.routes.draw do
  devise_for :users, :controllers => { :omniauth_callbacks => "users/omniauth_callbacks" }

  devise_scope :user do
    get 'sign_in', :to => 'users/sessions#new', :as => :new_user_session
    get 'sign_out', :to => 'users/sessions#destroy', :as => :destroy_user_session
  end

  root :to => "Landing#index"
end

app/model/user.rb

class User < ActiveRecord::Base
  # Include default devise modules. Others available are:
  # :token_authenticatable, :confirmable,
  # :lockable, :timeoutable and :omniauthable
  # :database_authenticatable, :registerable
  # :recoverable, :rememberable, :trackable, :validatable

  devise :omniauthable

  # Setup accessible (or protected) attributes for your model
  # attr_accessible :email, :password, :password_confirmation, :remember_me
  # attr_accessible :title, :body
end

config/intitializers/omniauth.rb

Rails.application.config.middleware.use OmniAuth::Builder do
  provider :google_oauth2, 'ID', 'SECRET', :scope => 'https://www.googleapis.com/auth/analytics.readonly'
end

app/controllers/users/omniauth_callback_controller.rb

class Users::OmniauthCallbacksController < Devise::OmniauthCallbacksController
  def google_oauth2
    # You need to implement the method below in your model
    @user = User.find_for_google_oauth2(request.env["omniauth.auth"], current_user)

    if @user.persisted?
      flash[:notice] = I18n.t "devise.omniauth_callbacks.success", :kind => "Google"
      sign_in_and_redirect @user, :event => :authentication
    else
      session["devise.google_data"] = request.env["omniauth.auth"]
      redirect_to new_user_registration_url
    end
  end
end

你能帮我理解这里有什么问题吗?

PS这是我运行的结果rake routes

user_omniauth_callback    /users/auth/:action/callback(.:format)  users/omniauth_callbacks#(?-mix:(?!))
new_user_session GET     /sign_in(.:format)                      users/sessions#new
destroy_user_session GET /sign_out(.:format)                     users/sessions#destroy
root                     /                                       Landing#index
4

1 回答 1

1

您正在运行什么版本的设计?这个已关闭的问题似乎处理了同样的问题,并假设它将在版本 1.4.9 中修复并提供快速而肮脏的修复。

但是,如果它没有帮助,请尝试将新会话的命名路由更改为:

get 'sign_in', :to => 'users/sessions#new', :as => :new_session

另外,我问了关于使用 Omniauth 进行设计的问题,您可能会觉得这很有用:设计 Omniauthable 使用 `Could not find a valid mapping for path` 破坏 Omniauth 身份验证

于 2012-06-12T20:50:05.373 回答