質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

Q&A

1回答

1085閲覧

【Ruby on Railsチュートリアル 第10章】フレンドリーフォワーディングが実装できない

pecchan

総合スコア555

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

0グッド

0クリップ

投稿2019/05/06 06:32

ちょうど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

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

app/controllers/sessions_controller.rb

Ruby

1def create 2 user = User.find_by(email: params[:session][:email].downcase) 3 if user && user.authenticate(params[:session][:password]) 4 log_in user 5 redirect_to user #ココ

でuserページにリダイレクトしているのでユーザー詳細ページに飛んでしまいます。

redirect_to userを

redirect_back_or(user)
(メソッドはapp/helpers/sessions_helper.rbで定義済み)
に変更するとフレンドリーフォワーディングが実装できるはずです。

投稿2019/05/15 07:26

編集2019/05/15 07:28
tttu

総合スコア26

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

pecchan

2019/05/16 08:30

有難う御座います。 redirect_back_or(user) と変更しましたが、変わりませんでした。 詳細ページ(users/id)に飛ばされます。
tttu

2019/05/16 11:03

session.helperはapplication.controllerで呼び出されていますか?? (store_locationメソッドをuser.controller内で使うために必要です。)
pecchan

2019/05/17 00:51

度々有難う御座います。 application.controller確認しました。 以下のようになってたので呼び出していると思うのですが・・。 class ApplicationController < ActionController::Base protect_from_forgery with: :exception include SessionsHelper end
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問