ユーザーのサインアウト方法に問題があります。ほとんどの場合、メソッドは更新後にのみ現在のサインアウトを行います。それをより明確にするために、次のようになります。ユーザーがサインアウトすると、ページはホームページにリダイレクトされ、ヘッダーに表示されているサインインしているユーザーが使用できるすべてのオプションを使用して、サインインしているユーザーが引き続き表示されます。ページを更新するまで、ユーザーは完全にはサインアウトされません。意図したとおりに動作することもありますが、ほとんどの場合はそうではありません。
これが私の SessionController destroy メソッドです:
def destroy
close_project
sign_out
redirect_to root_url
end
そして私のSessionHelper:
def sign_in(user)
remember_token = User.new_remember_token
cookies.permanent[:remember_token] = remember_token
user.update_attribute(:remember_token, User.encrypt(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
remember_token = User.encrypt(cookies[:remember_token])
@current_user ||= User.find_by(remember_token: remember_token)
end
def sign_out
self.current_user = nil
cookies.delete(:remember_token)
end
なぜこれが起こっているのか考えてみてください。