0

ユーザーのサインアウト方法に問題があります。ほとんどの場合、メソッドは更新後にのみ現在のサインアウトを行います。それをより明確にするために、次のようになります。ユーザーがサインアウトすると、ページはホームページにリダイレクトされ、ヘッダーに表示されているサインインしているユーザーが使用できるすべてのオプションを使用して、サインインしているユーザーが引き続き表示されます。ページを更新するまで、ユーザーは完全にはサインアウトされません。意図したとおりに動作することもありますが、ほとんどの場合はそうではありません。

これが私の 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

なぜこれが起こっているのか考えてみてください。

4

1 に答える 1

0

おそらくキャッシュの問題に直面しています。ログインしているユーザーとログアウトしているユーザーの両方が home_url にアクセスできる場合は、ページを少なくともプライベート キャッシュ可能とマークすることが重要です。開発環境でも発生しますか?

あなたの問題は、これにも関連している可能性があります: Cookie を設定してリダイレクトできないのはなぜですか?

于 2013-09-14T14:04:29.603 に答える