ちょうど1年前にもteratail内にて同質問がありましたが、回答が付いておりませんでした。
↓
Rails tutorial 10章のフレンドリーフォワーディングが実装できない
ログイン前に編集ページにアクセスし、ログインしたら編集ページにリダイレクトするはずが
ユーザー詳細ページに飛んでしまう状況です。
分かる方教えてください。
宜しくお願い致します。
app/controllers/users_controller.rb
ruby
1class UsersController < ApplicationController 2 3 before_action :logged_in_user, only: [:edit, :update] 4 before_action :correct_user, only: [:edit, :update] 5 6 def show 7 @user = User.find(params[:id]) 8 9 end 10 11 def new 12 @user = User.new 13 end 14 15 def create 16 @user = User.new(user_params) 17 if @user.save 18 log_in @user 19 flash[:success] = "Welcome to the Sample App!" 20 redirect_to @user 21 else 22 render 'new' 23 end 24 end 25 26 def edit 27 @user = User.find(params[:id]) 28 end 29 30 def update 31 @user = User.find(params[:id]) 32 if @user.update_attributes(user_params) 33 # 更新成功 34 flash[:success] = "Profile updated" 35 redirect_to @user 36 else 37 render 'edit' 38 end 39 end 40 41 private 42 43 def user_params 44 params.require(:user).permit(:name, :email, :password, 45 :password_confirmation) 46 end 47 48 # ログイン済みユーザーかどうか確認 49 def logged_in_user 50 unless logged_in? 51 store_location 52 flash[:danger] = "Please log in." 53 redirect_to login_url 54 end 55 end 56 57 # 正しいユーザーかどうか確認 58 def correct_user 59 @user = User.find(params[:id]) 60 redirect_to(root_url) unless current_user?(@user) 61 end 62 63 64 65 66 67end 68
app/helpers/sessions_helper.rb
ruby
1module SessionsHelper 2 3 #渡されたユーザーでログインする 4 def log_in(user) 5 session[:user_id] = user.id 6 end 7 8 #現在ログイン中のユーザーを返す (いる場合) 9 def current_user 10 if session[:user_id] 11 @current_user ||= User.find_by(id: session[:user_id]) 12 end 13 end 14 15 #ユーザーがログインしていればtrue、その他ならfalseを返す 16 def logged_in? 17 !current_user.nil? 18 end 19 20 # 現在のユーザーをログアウトする 21 def log_out 22 session.delete(:user_id) 23 @current_user = nil 24 end 25 26 # 渡されたユーザーがログイン済みユーザーであればtrueを返す 27 def current_user?(user) 28 user == current_user 29 end 30 31 32 33 # 記憶したURL (もしくはデフォルト値) にリダイレクト 34 def redirect_back_or(default) 35 redirect_to(session[:forwarding_url] || default) 36 session.delete(:forwarding_url) 37 end 38 39 # アクセスしようとしたURLを覚えておく 40 def store_location 41 session[:forwarding_url] = request.original_url if request.get? 42 end 43 44 def create 45 user = User.find_by(email: params[:session][:email].downcase) 46 if user && user.authenticate(params[:session][:password]) 47 log_in user 48 params[:session][:remember_me] == '1' ? remember(user) : forget(user) 49 redirect_back_or user 50 else 51 flash.now[:danger] = 'Invalid email/password combination' 52 render 'new' 53 end 54 end 55 56 57end 58
app/controllers/sessions_controller.rb
ruby
1class SessionsController < ApplicationController 2 3 def new 4 end 5 6 def create 7 user = User.find_by(email: params[:session][:email].downcase) 8 if user && user.authenticate(params[:session][:password]) 9 log_in user 10 redirect_to user 11 else 12 flash.now[:danger] = "Invalid email/password combination" 13 render 'new' 14 end 15 end 16 17 def destroy 18 log_out 19 redirect_to root_path 20 end 21end 22
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2019/05/16 08:30
2019/05/16 11:03
2019/05/17 00:51