2

Hartl のチュートリアルで Rails を学んでいますが、9.2.3 章のLink to workを取得できます。

このセクションの前はすべて完全に機能していましたが、ここにたどり着いた後、/users/1/edit にアクセスして別のユーザーまたは同じユーザーでログインすると、編集ページではなくユーザー ページにリダイレクトされます。

セッションヘルパー:

def redirect_back_or(default)
    redirect_to(session[:return_to] || default)
    session.delete(:return_to)
end

def store_location
    session[:return_to] = request.fullpath
end

before_filter のユーザー コントローラー メソッド

private

def signed_in_user
  unless signed_in?
    store_location
    redirect_to signin_path, notice: "Please sign in."
  end
end

def correct_user
  @user = User.find(params[:id])
  redirect_to(root_path) unless current_user?(@user)
end

ユーザーコントローラーのフィルターの前

before_filter :signed_in_user,only:[:edit,:update,:index]
before_filter :correct_user, only:[:edit,:update]

これまでの私のコードGithub

4

1 に答える 1

2

SessionsController の create で、redirect_to の代わりに redirect_back_or user の呼び出しに失敗しました。

  def create
    user = User.find_by_email(params[:session][:email])
      if user && user.authenticate(params[:session][:password])
        sign_in user
        redirect_back_or user
      else
        flash.now[:error] = 'Invalid email/password combination' # Not quite right!
        render 'new'
      end
  end

ページの下部にあるデバッグ情報にセッションを追加すると、ログインが成功した後も return_to が残っていたことがわかりました。

{"session_id"=>"4dcc1baaf651aaab953026902b32f805", "_csrf_token"=>"0YkP+yd/DDuInX4kIBkjwbzxV1GK0oYBDAXEiWnHLGs=", "return_to"=>"/users/1/edit"}
于 2012-07-29T19:54:40.880 に答える