久しぶりにrailsアプリを起動したら、view側でcurrent_userの値が取得できませんでした。いろいろ試してみたのですがどうしても呼べないのですがご教授願えますでしょうか。
#やってみたこと
●controller側でbefore_action :authenticate_user!の記載があることを確認
●deviseのサインインができることの確認
●rails dbconsoleでusersテーブルが存在し、アカウントレコードが入っていることを確認
以下ソースです。
routes.rb
ruby
1Rails.application.routes.draw do 2 3 devise_for :users 4 get 'home/index' 5 post 'carts/index' 6 post 'projects/user_detail' 7 resources :projects 8 #root 'home#index' 9 root 'projects#index' 10end
controller
ruby
1class ProjectsController < ApplicationController 2 PER = 5 3 before_action :set_project, only: [:show,:edit, :update, :destroy] 4 5 def index 6 7 if params[:title].present? && params[:star].present? || params[:title].present? 8 @projects = Project.search(params[:title]).page(params[:page]).per(PER) 9 elsif params[:star].present? 10 @projects = Project.joins(:reviews).preload(:reviews).merge(Review.star(params[:star])).page(params[:page]).per(PER) 11 else 12 @projects = Project.with_deleted.page(params[:page]).per(PER) 13 #@projects = Project.page(params[:page]).per(PER) 14 #@projects = Project.with_deleted 15 16 end 17 18 if params[:title].frozen? 19 @projects = Project.all 20 end 21 22 end 23 def show 24 25 @click = Click.find_by_project_id(params[:id]) 26 params[:project_id] = params[:id] 27 params[:user_id] = 1 28 @clicked = Click.new(clicked_params) 29 @clicked.save 30 @user = current_user 31 @r = Project.joins("LEFT OUTER JOIN reviews ON projects.id = reviews.project_id LEFT OUTER JOIN user_items ON user_items.user_id = reviews.user_id").where("reviews.project_id = ?" , params[:id]).select("projects.* , reviews.* , user_items.*") 32 @cart = Project.where("id = ? ", params[:id]) 33 @descryption = ItemDesc.find(params[:id]) 34 end 35
#事象
showメソッドを読んだ段階で下記エラーが発生
NoMethodError in Project#show
undefined method `email' for nil:NilClass
ruby
1 こんにちは! 2 <a href="https://koukisyukatunavi.jp/login" class="btn btn-green"> 3 4 <%= @user.email %> 5 さん 6 <%= link_to 'ログアウト' , destroy_user_session_path %> 7 <% else %>
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。