1

我正在开发一个应用程序,该应用程序具有多个需要用户登录才能访问的区域。(我正在使用逻辑设计)。

我目前在我的应用程序控制器中使用以下内容来记住目标 url(某人单击的链接(需要身份验证)),以便在身份验证后将用户带到那里(根据How to direct user to a specific page after logging在设计和 Rails 中)。

class ApplicationController < ActionController::Base
  helper :content
  protect_from_forgery


  def after_sign_in_path_for(user)
    origin_path = session[:origin_path]
    default_redirect_path ="/"
    clear_origin_path
    if origin_path.present?
      origin_path
    else
      params[:target].presence || default_redirect_path
    end
  end

  private

  def authenticate_user!
    store_origin_path
    super
  end

    def store_session
    store_origin_path

  end

  def store_origin_path
    session[:origin_path] = request.fullpath
  end

  def clear_origin_path
    session[:origin_path] = nil
  end


end

这一切都很好,但我刚刚注意到,当我尝试访问“/users/edit”时,我现在得到了错误:

ArgumentError in Devise::RegistrationsController#edit

wrong number of arguments (1 for 0)
Rails.root: /home/james/*******

Application Trace | Framework Trace | Full Trace
app/controllers/application_controller.rb:19:in `authenticate_user!'
Request

Parameters:

None
Show session dump

_csrf_token: "XmrTSQOQ3Z0XTSn14LAX8LtMNVOwM4q3bQ+UhxjvgGM="
session_id: "2caaccc944774f2a7ac6f440c2f442d9"
user_return_to: "/my_tendersave"
warden.user.user.key: ["User", [1], "$2a$10$foTK/Em72/E0rILIuUv7su"]
warden.user.user.session: {"last_request_at"=>2013-01-25 01:48:43 UTC}
Show env dump

GATEWAY_INTERFACE: "CGI/1.2"
HTTP_ACCEPT: "text/html,application/xhtml+xml,application/xml;q=0.9,*/*;q=0.8"
HTTP_ACCEPT_CHARSET: "ISO-8859-1,utf-8;q=0.7,*;q=0.3"
HTTP_ACCEPT_ENCODING: "gzip,deflate,sdch"
HTTP_ACCEPT_LANGUAGE: "en-GB,en-US;q=0.8,en;q=0.6"
REMOTE_ADDR: "127.0.0.1"
SERVER_NAME: "localhost"
SERVER_PROTOCOL: "HTTP/1.1"
Response

Headers:

None

我能做些什么来确保它有效?

我需要更改应用程序控制器吗?

或覆盖其他一些设计方法。

在此先感谢您的帮助。

4

1 回答 1

2

我只是重命名了应用程序控制器中的方法并调用了正确的超类方法。

IE。

  def authenticated_user!
    store_origin_path
    authenticate_user!
  end
于 2013-01-28T02:24:54.863 回答