我在我的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