我正在关注http://ruby.railstutorial.org上的教程
具体来说,第 9 章(9.2.3) http://ruby.railstutorial.org/chapters/updating-showing-and-deleting-users#top
当用户在访问受限页面时被提示登录然后在成功登录后被重定向回受限页面时,我已经设法获得了部分。
我正在尝试获取它,以便在重定向到受保护页面后,下一次登录尝试将直接返回主用户个人资料页面,但是,session.delete(:return_to)
似乎没有工作,并且用户被反复引导回原来的页面保存的受保护页面。这是我的代码:
我的会话控制器:
class SessionsController < ApplicationController
def new
end
def create
user = User.find_by_email(params[:session][:email])
if user && user.authenticate(params[:session][:password])
sign_in user
redirect_back_or user
# Sign the user in and redirect to the user's show page.
else
# Create an error message and re-render the signin form.
flash.now[:error] = 'Invalid email/password combination'
render 'new'
end
end
...
end
我的会话助手:
module SessionsHelper
def sign_in(user)
cookies.permanent[:remember_token] = user.remember_token
self.current_user = user
end
def signed_in?
!current_user.nil?
end
def current_user=(user)
@current_user = user
end
def current_user
@current_user ||= User.find_by_remember_token(cookies[:remember_token])
end
def current_user?(user)
user == current_user
end
def sign_out
self.current_user = nil
cookies.delete(:remember_token)
end
def redirect_back_or(default)
redirect_to(session[:return_to] || default)
session.delete(:return_to)
end
def store_location
session[:return_to] = request.url
end
end
您可以提供的任何帮助都会很棒!似乎session.delete()
根本行不通。