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

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

ただいまの
回答率

89.72%

rails ransack導入時に500error

受付中

回答 0

投稿

  • 評価
  • クリップ 1
  • VIEW 71

bok_sakai

score 14

前提・実現したいこと

Rails6で小説や漫画、映画などのレビューアプリを制作しています。
検索機能を導入したく、参考サイト(https://qiita.com/nojinoji/items/e1b174220da8c81a1756)をもとにransackをインストールして作業を進めていたのですが、エラーが発生しました。

コードが足りない場合はお手数ですがコメントお願いします。追加いたします。

自分の力ではどうにもなりません、、。ご教授お願いします。

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

先述したサイトを始め様々な情報源をもとに導入を進めていたのですが、どうしても上手くいかず、下記のような画面が出てきます。

![

ログはこんな感じです。

Started GET "/search" for ::1 at 2019-10-23 02:49:09 +0900
Processing by HomeController#search as HTML
  User Load (0.3ms)  SELECT "users".* FROM "users" WHERE "users"."id" IS NULL LIMIT ?  [["LIMIT", 1]]
  ↳ app/controllers/application_controller.rb:20:in `set_current_user'
  Rendering home/search.html.erb within layouts/application
  Post Load (0.2ms)  SELECT DISTINCT "posts".* FROM "posts" LIMIT ?  [["LIMIT", 11]]
  CACHE Post Load (0.0ms)  SELECT DISTINCT "posts".* FROM "posts" LIMIT ?  [["LIMIT", 11]]
  CACHE Post Load (0.0ms)  SELECT DISTINCT "posts".* FROM "posts" LIMIT ?  [["LIMIT", 11]]
  CACHE Post Load (0.0ms)  SELECT DISTINCT "posts".* FROM "posts" LIMIT ?  [["LIMIT", 11]]
  CACHE Post Load (0.0ms)  SELECT DISTINCT "posts".* FROM "posts" LIMIT ?  [["LIMIT", 11]]
  CACHE Post Load (0.0ms)  SELECT DISTINCT "posts".* FROM "posts" LIMIT ?  [["LIMIT", 11]]
  CACHE Post Load (0.0ms)  SELECT DISTINCT "posts".* FROM "posts" LIMIT ?  [["LIMIT", 11]]
  CACHE Post Load (0.0ms)  SELECT DISTINCT "posts".* FROM "posts" LIMIT ?  [["LIMIT", 11]]
  Rendered home/search.html.erb within layouts/application (Duration: 247.3ms | Allocations: 213060)
Completed 500 Internal Server Error in 251ms (ActiveRecord: 0.7ms | Allocations: 214355)

該当のソースコード

#home/search.html.erb

<body>
    <%= search_form_for @q do |f| %>
        <%= f.label :title, "Keyword" %>
        <%= f.search_field :title_cont %>
        <%= f.submit "検索" %>
    <% end %>
</body>

Controller

#home_controller.rb

class HomeController < ApplicationController

  def review
    @post = Post.all.order(created_at: :desc)
  end

  #before_filter :set_search 

  def search
    @q = Post.ransack(params[:q])
    @post = Post.all
    @post = @q.result(distinct: true)
  end

  def set_search
    @q = Post.search(search_params)
    @post = @q.result(distinct: true)
  end

  private

  def search_params
    params.require(:q).permit(:title_cont)
  end
end
#posts_controller.rb

class PostsController < ApplicationController
  protect_from_forgery except: :update
  before_action :ensure_correct_user,{only: [:edit,:update,:destroy]}


  def show
    @id = params[:id]
    @post = Post.find_by(id: params[:id])
    @user = User.find_by(id: @post.user_id)
  end

  def edit
    @post = Post.find_by(id: params[:id])
  end

  def update
    @post = Post.find_by(id: params[:id])
    @post.title = params[:title]
    @post.content = params[:content]
    @post.workname = params[:workname]
    @post.author = params[:author]
    @post.style = params[:style]
    @post.save
    redirect_to("/")
  end

  def destroy
    @post = Post.find_by(id: params[:id])
    @post.destroy
    redirect_to("/")
  end

  def ensure_correct_user
    @post = Post.find_by(id:params[:id])
    unless @post.user_id == current_user&.id
      flash[:notice] = "権限がありません"
      redirect_to("/posts/index")
    end
  end

end

postモデル

#post.rb

class Post < ApplicationRecord
    belongs_to :user

    validates :title, presence: true, length: { in: 3..50 }
    validates :content, presence: true, length: { in: 10..20000 }
    validates :workname, presence: true
    validates :author, presence: true
end

routes

#routes.rb

Rails.application.routes.draw do

  #-順番変えちゃダメ---------------------------------------

  # 新規登録・ログイン後のページを指定
  root to: "home#top" 

  # ログイン、アカウント編集後、任意のページに推移させるための記述
  devise_for :users, :controllers => {
    :registrations => 'users/registrations',
    :sessions => 'users/sessions'   
  } 

  devise_scope :user do
    get "signup", :to => "users/registrations#new"
    get "login", :to => "users/sessions#new"
    get "logout", :to => "users/sessions#destroy"
    get 'users/:id/setting', to: 'users/registrations#edit'
    patch 'users/:id/update', to: 'users/registrations#update'
  end

  resources :users, only: [:show]

  #----------------------------------------------------

  # ホームページ
  get '/' => "home#top"

  # 検索ぺージ
  get 'search' => "home#search"
  get 'set_search' => "home#set_search"

  # 新規ヒョーロン投稿関係
  # 新規投稿アクションと投稿の編集・削除アクションが別のコントローラーで定義されているため、このようなコードになっています。わかりにくくてすみません。
  get 'posts/new' => "login_user#newpost"
  post 'posts' => "login_user#create"
  resources :posts
  get 'created' => "login_user#postcreate"

  #アカウント編集ページ
  get 'users/:id/account/edit' => "users#edit"

  # ユーザー詳細ページ
  get 'users/:id' => "users#show"

  # For details on the DSL available within this file, see https://guides.rubyonrails.org/routing.html
end

試したこと

@postを@postsに変更
before_filter :set_search をdef set_search … endの直前に追加
<%= search_form_for(@q, url:search_path) do |f| %> を <%= search_form_for @q do |f| %>に変更

以上の3つを試してみましたが、すべて同じエラー画面が表示されました。

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

まだ回答がついていません

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

  • ただいまの回答率 89.72%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

同じタグがついた質問を見る