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

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

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

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

Q&A

解決済

1回答

1128閲覧

before_actionを実装した後、削除機能ができなくなった

YugoTokonami

総合スコア21

Ruby on Rails

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

1グッド

1クリップ

投稿2021/08/31 04:01

前提・実現したいこと

オリジナルアプリ(ブログ的な)を作成しています。
before_action move_to_indexで「URLに直接入力(編集など)して、ログインしていないユーザーが他のユーザーの記事を編集しようとするとトップページに遷移する」機能を実装した後、アプリの挙動を確認していたところ、記事の削除をしようとすると、エラーになってしまい、削除ができなくなってしまいました。

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

NoMethodError in ArticlesController#destroy undefined method `user' for nil:NilClass Did you mean? super def move_to_index←ここがおかしいと言われている unless current_user.id == @article.user.id redirect_to action: :index end end

articles_controller

class ArticlesController < ApplicationController before_action :authenticate_user!, except: [:index, :show] before_action :set_article, only: [:edit, :show] before_action :move_to_index, except: [:index, :new, :create, :show,] def index @articles = Article.order("created_at DESC") end def new @article = Article.new end def create @article = Article.new(article_params) if @article.save redirect_to root_path else render :new end end def destroy article = Article.find(params[:id]) article.destroy end def edit end def update article = Article.find(params[:id]) article.update(article_params) if article.valid? redirect_to article_path(article.id) else render :edit end end def show @comment = Comment.new @comments = @article.comments.includes(:user) end private def article_params params.require(:article).permit(:image, :title, :profile, :text, :category_id, ).merge(user_id: current_user.id) end def set_article begin @article = Article.find(params[:id]) rescue render :destroy end end def move_to_index unless current_user.id == @article.user.id redirect_to action: :index end end end

destroy.rb

<div class="article-delete"> <%= link_to 'B-blog', root_path, class:"delete-header-text" %> <div class="delete-main"> <div class="success"> <div class="delete-text"> 削除完了しました </div> <%= link_to 'トップページに戻る', root_path, class: "return-btn" %> </div> </div> </div>

試したこと

エラーの内容を調べたところ、「ユーザーが空だからわからない」と言われています。move_to_indexにuserは記述しているのですが、それでも「空です」と言われているので、コントローラーで正しくuserの定義ができていない?のかと思います。

どなたかエラーの解決を教えて頂けると幸いです。

shinoharat👍を押しています

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

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

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

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

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

guest

回答1

0

ベストアンサー

エラーの内容を調べたところ、「ユーザーが空だからわからない」と言われています。

いえ、そのエラーメッセージの意味は
「存在しないメソッドを呼び出そうとしました。Nil クラスに user というメソッドは存在しません。」
です。

つまり、move_to_index メソッドの

rb

1@article.user.id

の部分を

rb

1(nil).user.id

と解釈しています。

@article が nil になっているのが原因なので、 destroy のときも set_article が呼び出されるようにすれば解決すると思います。

diff

1- before_action :set_article, only: [:edit, :show] 2+ before_action :set_article, only: [:edit, :show, :destroy]

投稿2021/08/31 05:13

shinoharat

総合スコア1680

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

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

YugoTokonami

2021/08/31 05:29

回答ありがとうございます! 回答を参考にした結果、解決ができました! ・set_articleにdestroy追加→article.rbのcommentsのアソシエーションに、dependent: :destroyを追加で正しく削除ができるようになりました! ありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.46%

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

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

質問する

関連した質問