我在我的application_controller中有标准的current_user方法。authlogic current_user是无
def current_user_session
return @current_user_session if defined?
(@current_user_session)
@current_user_session = UserSession.find
end
def current_user
return @current_user if defined?(@current_user)
@current_user = current_user_session &&
current_user_session.record
end
在我UserSessionController创建方法,我查 registration_complete? (简单地检查一列的值,其中 工作正常),然后如果 注册未完成,则将用户重定向到用户编辑页面。当我调试这个时,我可以看到已尝试记录@user_session对象存在,它指向 给正确的用户,但 中的current_user方法的redirect_to edit_user_path(current_user), 始终返回nil。
这里怎么回事?
def create
@user_session = UserSession.new(params[:user_session])
# uses a block to prevent double render error...
# because oauth and openid use redirects
@user_session.save do |result|
if result
flash[:notice] = "Login successful!"
if @user_session.new_registration?
logger.info "Session controller : new
registration"
logger.info "Complete -
#{@user_session.registration_complete?}"
flash[:notice] = "Please review profile"
redirect_to edit_user_path(current_user)
else
if @user_session.registration_complete?
logger.info "Session Controller - registration
complete"
else
flash[:notice] = "Please complete profile"
logger.info "Session Controller - registration
not complete"
redirect_to edit_user_path(current_user)
#current_user nil here
end
end
redirect_to current_user ? profile_url(current_user) :
login_url
else
if @user_session.errors.on(:user)
# if we set error on the base object, likely it's
because we didn't find a user
render :action => :confirm
else
render :action => :new
end
end
end
end
如果你还是想回答这个问题...请参阅回答问题http://stackoverflow.com/q/5305306/1188763希望这有助于! – Norto23 2012-04-11 00:05:59