4

我想更改设计的用户登录行为,以便在未确认用户时将用户重定向到不同的页面。

我的代码中有以下代码app/controllers/sessions_controller.rb

  # POST /user/sign_in
  def create

    @user = warden.authenticate!(:scope => :user) 
    sign_in @user
     respond_with @user, :location => after_sign_in_path_for(@user)

  end

当用户输入正确的用户名/密码并且未确认时,Warden 将引发错误,将用户重定向到登录页面(代码 302)。同时这会将 flash[:alert] 设置为“未确认”。

有没有办法将未经确认的用户重定向到特定页面?

我解决这个问题的想法是读取 flash[:alert] 值并在该值“未确认”时重定向到适当的页面,但看守没有发送有关用户的其他数据。

4

4 回答 4

2
class SessionsController < Devise::SessionsController
  def create
    @user = User.where(:email => params[:user][:email])[0] # you get the user now
    if @user.confirmed?
      super
    else
      redirect_to YOUR_DESIRED_path # or something else you want to do
    end
  end
end
于 2013-01-22T06:28:50.013 回答
2

You need a custom FailureApp to do this (and you need to define /unconfirmed in your routes, etc., like any other Rails action):

lib/custom_failure.rb

class CustomFailure < Devise::FailureApp
  def redirect_url
    if warden_message == :unconfirmed
      '/unconfirmed'
    else
      super
    end
  end

  # You need to override respond to eliminate recall
  def respond
    if http_auth?
      http_auth
    else
      redirect
    end
  end
end

config/initializers/devise.rb:

  config.warden do |manager|
    manager.failure_app = CustomFailure
  end
于 2016-12-22T01:18:06.500 回答
0

我认为要使这项工作正常进行,您需要将 Brian 的答案与您的 routes.rb 文件的附加内容结合起来。

我现在要对其进行测试,所以如果/当我让它工作时,我会给你一个更新。(编辑:我在本地工作)。

这是您需要做的:

  1. your_rails_app/app/controllers在调用中创建一个新文件,该文件sessions_controller.rb应如下所示:

    class SessionsController < Devise::SessionsController
      def create
        @user = User.where(:email => params[:user][:email])[0] # you get the user now
        if @user.confirmed?
          super
        else
          redirect_to YOUR_DESIRED_path # or something else you want to do
        end
      end
    end
    
  2. 将以下行添加到您的 routes.rb 文件中(或修改您的 routes.rb 文件中包含devise_for :users...或您的模型所称的任何内容的行):

    devise_for :users, controllers: { sessions: "sessions" }
    
  3. 您需要将此添加到您的User模型中:

     protected
     def confirmation_required?
       false
     end
    
于 2016-02-04T22:12:43.393 回答
-1

如果您不想让未经确认的用户在注册成功后登录,请将此行放入 devise.rb。

config.allow_unconfirmed_access_for = nil 
于 2013-12-11T10:34:23.847 回答