ユーザーがアクセスするためにログインする必要があるいくつかの領域を持つアプリケーションに取り組んでいます。(私はロジックにdeviseを使用しています)。
現在、アプリケーションコントローラーで次を使用して、ターゲットURL(誰かがクリックしたリンク(認証が必要なリンク))を記憶して、認証後にユーザーをそこに連れて行くようにしています(ログ後にユーザーを特定のページに誘導する方法に従って) Devise と 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
これが確実に機能するようにするにはどうすればよいですか?
アプリケーションコントローラーを変更する必要がありますか?
または、他のデバイス メソッドをオーバーライドします。
よろしくお願いします。