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

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

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

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

Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

AWS(Amazon Web Services)

Amazon Web Services (AWS)は、仮想空間を機軸とした、クラスター状のコンピュータ・ネットワーク・データベース・ストーレッジ・サポートツールをAWSというインフラから提供する商用サービスです。

Q&A

解決済

1回答

2435閲覧

タスク管理アプリにログイン後にログインページにリダイレクトされてしまう

退会済みユーザー

退会済みユーザー

総合スコア0

Ruby on Rails 5

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

Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

AWS(Amazon Web Services)

Amazon Web Services (AWS)は、仮想空間を機軸とした、クラスター状のコンピュータ・ネットワーク・データベース・ストーレッジ・サポートツールをAWSというインフラから提供する商用サービスです。

0グッド

1クリップ

投稿2020/02/13 10:55

前提・実現したいこと

ログイン後にタスク管理アプリの一覧を表示させるようにしたいです。

発生している問題・エラーメッセージ

ログインしてもログインページにリダイレクトされてしまいます。

以下の画像になります。

イメージ説明

該当のソースコード

該当する可能性のあるソースコードです。

sessions_controller.rb

class SessionsController < ApplicationController def new end def create email = params[:session][:email].downcase password = params[:session][:password] if login(email, password) flash[:success] = "ログインに成功しました。" redirect_to root_url else flash.now[:danger] = "ログインに失敗しました。" render :new end end def destroy session[:user_id] = nil flash[:success] = "ログアウトしました。" redirect_to root_url end private def login(email, password) @user = User.find_by(email: email) if @user && @user.authenticate(password) # ログイン成功(sessionとcookieのログイン情報を照合) session[:user_id] = @user_id return true else #ログイン失敗 return false end end end

tasks_controller.rb

class TasksController < ApplicationController before_action :require_user_logged_in before_action :correct_user, only: [:destroy, :show, :update, :edit] # before_action :set_task, only: [:show, :edit, :update, :destroy] def index @tasks = current_user.tasks.order(id: :desc).page(params[:page]).per(10) end def create @task = Task.new(task_params) if @task.save flash[:success] = "タスクが正常に追加されました" redirect_to @task else flash.now[:danger] = "タスクが正常に投稿されませんでした。" render :new end end def new @task = Task.new end def edit end def show end def update if @task.update(task_params) flash[:success] = "タスク内容は正常に更新されました" redirect_to @task else flash.now[:danger] = "タスク内容は正常に更新されませんでした" render :edit end end def destroy @task.destroy flash[:success] = "タスクは正常に削除されました" redirect_to tasks_url end private # tasks_controller.rb内の@task = Task.find(params[:id])の部分テンプレート(パーション) #def set_task # @task = Task.find(params[:id]) #end #Strong parameter def task_params params.require(:task).permit(:content, :status) end def correct_user @task = current_user.tasks.find_by(id: params[:id]) unless @task redirect_to root_url end end end

application_controller.rb

class ApplicationController < ActionController::Base include SessionsHelper private def require_user_logged_in unless logged_in? redirect_to login_url end end end

sessions_helper.rb

module SessionsHelper def current_user @current_user ||= User.find_by(id: session[:user_id]) end def logged_in? !!current_user end end

routes.rb

Rails.application.routes.draw do # For details on the DSL available within this file, see http://guides.rubyonrails.org/routing.html root to: "tasks#index" get "login", to: "sessions#new" post "login", to: "sessions#create" delete "logout", to: "sessions#destroy" get "signup", to: "users#new" resources :tasks resources :users, only: [:new, :create] end

users_controller.rb

class UsersController < ApplicationController def new @user = User.new end def create @user = User.new(user_params) if @user.save flash[:success] = "ユーザーを登録しました。" redirect_to login_url else flash.now[:danger] = "ユーザーを登録できませんでした。" render :new end end def show end def index end #Strong Parameter private def user_params params.require(:user).permit(:name, :email, :password, :password_confirmation) end end

試したこと

before_actionの定義しているコントローラーに誤りがないか確認をしました。
また、テキストの手順通り行っているか確認をしたのですが原因を見つけることが出来ませんでした。

補足情報(FW/ツールのバージョンなど)

Rails 5.2.2

Ruby 2.5.3

AWS Cloud9

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

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

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

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

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

guest

回答1

0

ベストアンサー

SessionsController@user_id@user.idだと思いました。
@user_idはどこにも定義されていないので、session[user_id]nilのような値が入っている用に見えます。
なので、require_user_logged_inメソッドのなかでログイン判定がfalseになってlogin_urlにリダイレクトされていると思います。

こちらに修正したコードを記載します。

rb

1class SessionsController < ApplicationController 2 ... 3 4 private 5 6 def login(email, password) 7 @user = User.find_by(email: email) 8 if @user && @user.authenticate(password) 9 # ログイン成功(sessionとcookieのログイン情報を照合) 10 session[:user_id] = @user.id # ここを修正しました。 11 return true 12 else 13 #ログイン失敗 14 return false 15 end 16 end 17end

投稿2020/02/13 11:24

shgtkshruch

総合スコア665

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

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

退会済みユーザー

退会済みユーザー

2020/02/13 13:00

ご指摘頂いたところを修正した結果、無事にタスク一覧画面に遷移しました。 ありがとうございました。
shgtkshruch

2020/02/13 13:15

無事に解決できてよかったです〜。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問