用Devise登录后奇怪的重定向

时间:2011-11-10 18:19:27

标签: ruby-on-rails-3 devise

我有这个应用程序,我使用Devise,登录后,用户被重定向到一个路径为/users/sign_in.user的空白页面。

为什么Devise会重定向到此路径?这是我得到的日志条目:

Started POST "/users/sign_in.user" for 127.0.0.1 at 2011-11-10 15:56:03 -0200
  Processing by Users::SessionsController#create as 
  Parameters: {"utf8"=>"✓", "authenticity_token"=>"ukqyLFgApCSybuIlVynPwj/xgdI/WuHLxoFxOsY4wgQ=", "user"=>{"email"=>"felipe.coury@gmail.com", "password"=>"[FILTERED]", "remember_me"=>"0"}, "commit"=>"Entrar"}
  User Load (1.8ms)  SELECT `users`.* FROM `users` WHERE `users`.`email` = 'felipe.coury@gmail.com' LIMIT 1
   (0.2ms)  BEGIN
   (1.0ms)  UPDATE `users` SET `last_sign_in_at` = '2011-11-09 18:47:04', `current_sign_in_at` = '2011-11-10 17:56:04', `sign_in_count` = 14, `updated_at` = '2011-11-10 17:56:04' WHERE `users`.`id` = 1
   (0.3ms)  COMMIT
Completed 406 Not Acceptable in 112ms

这是我的完整routes.rb文件:

MyApp::Application.routes.draw do
  root :to => "site#home"
  match 'biblioteca' => 'site#library', :as => :library

  devise_for :users, :controllers => { :sessions => "users/sessions" }
  devise_for :admin_users, ActiveAdmin::Devise.config

  ActiveAdmin.routes(self)

  resources :cursos
  resources :matriculas
  resources :modulo_statuses
end

我尝试在after_sign_in_path_for中使用ApplicationController

def after_sign_in_path_for(resource_or_scope)
  Rails.logger.info "***** LOGGED IN, GOING TO #{root_path}"
  root_path
end

但是日志条目甚至没有出现。

有没有人知道为什么会这样?

1 个答案:

答案 0 :(得分:6)

这可能正在发生,因为这样的事情被调用:user_session_path(user)并且您实际上不需要用户作为参数,因此Rails将其视为格式。您在登录视图中的form_for来电可能存在错误。 after_sign_in_path_for未被调用,因为Rails没有将给定的URL视为有效请求(这就是为什么响应是可接受的)。