2

標準のデバイスsession_controllerを変更するにはどうすればよいですか。たとえば、間違ったパスワードを入力した場合、リダイレクトされます:back(必須ではありません)、エラーが表示されます...

私はこれが必要なのですか?すべてのページのレイアウト左ブロックにレンダリングされるテンプレートにのみログインしていて、新しいアクションビューがなかったため...

では、検証メッセージエラーでエラーを他のページにリダイレクトするにはどうすればよいですか...?

これが標準のsession_controllerです(今は作成していません。「ネスト」されています):

class Devise::SessionsController < DeviseController
  prepend_before_filter :require_no_authentication, :only => [ :new, :create ]
  prepend_before_filter :allow_params_authentication!, :only => :create
  prepend_before_filter { request.env["devise.skip_timeout"] = true }

  # GET /resource/sign_in
  def new
    self.resource = build_resource(nil, :unsafe => true)
    clean_up_passwords(resource)
    respond_with(resource, serialize_options(resource))
  end

  # POST /resource/sign_in
  def create
    self.resource = warden.authenticate!(auth_options)
    set_flash_message(:notice, :signed_in) if is_navigational_format?
    sign_in(resource_name, resource)
    respond_with resource, :location => after_sign_in_path_for(resource)
  end

  # DELETE /resource/sign_out
  def destroy
    redirect_path = after_sign_out_path_for(resource_name)
    signed_out = (Devise.sign_out_all_scopes ? sign_out : sign_out(resource_name))
    set_flash_message :notice, :signed_out if signed_out && is_navigational_format?

    # We actually need to hardcode this as Rails default responder doesn't
    # support returning empty response on GET request
    respond_to do |format|
      format.all { head :no_content }
      format.any(*navigational_formats) { redirect_to redirect_path }
    end
  end

  protected

  def serialize_options(resource)
    methods = resource_class.authentication_keys.dup
    methods = methods.keys if methods.is_a?(Hash)
    methods << :password if resource.respond_to?(:password)
    { :methods => methods, :only => [:password] }
  end

  def auth_options
    { :scope => resource_name, :recall => "#{controller_path}#new" }
  end
end

appcontrollerのメソッドも

def after_sign_in_path_for(resource)      
    case resource
      when User then 
        user = User.find(current_user.id)
        total_markup_for_user = user.groups.map(&:markup).sum
        if current_cart.present?
          cart_id = current_cart.id
        else
          cart_id = nil
        end
        ***
        end
        if request.referrer.to_s.include? "users"
          root_path
        else
          request.referrer 
        end
      when Admin::Admin then :admin_mainpage
    end
  end
4

2 に答える 2

3

Deviseには、デフォルトのリダイレクトをオーバーライドする方法を示すドキュメントがあります。

https://github.com/plataformatec/devise/wiki/How-To:-Redirect-to-a-specific-page-on-successful-sign-in

基本的には、application_controller.rbにアクセスして、たとえば次のように記述します。

def after_sign_in_path_for(resource)
  request.env['omniauth.origin'] || stored_location_for(resource) || new_survey_path
end

def after_sign_out_path_for(resource_or_scope)
 root_path
end

終わり

それが役に立てば幸い

于 2013-03-06T15:43:30.303 に答える
2

このようなことを試して、sign_inがfalseを返す場合に備えて、新しいrespond_withを追加してください。

def create
  self.resource = warden.authenticate!(auth_options)
  set_flash_message(:notice, :signed_in) if is_navigational_format?
  if sign_in(resource_name, resource)
    respond_with resource, location: after_sign_in_path_for(resource)
  else
    respond_with resource, location: root_path
  end
end
于 2013-03-06T13:41:55.917 に答える