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

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

ただいまの
回答率

89.71%

rails ransack導入時に500error

解決済

回答 2

投稿 編集

  • 評価
  • クリップ 2
  • VIEW 113

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

Gemfile

#Gemfile

source 'https://rubygems.org'
git_source(:github) { |repo| "https://github.com/#{repo}.git" }

ruby '2.6.1'

# Bundle edge Rails instead: gem 'rails', github: 'rails/rails'
gem 'rails', '~> 6.0.0'
# Use sqlite3 as the database for Active Record
gem 'sqlite3', '~> 1.4'
# Use Puma as the app server
gem 'puma', '~> 3.11'
# Use SCSS for stylesheets
gem 'sass-rails', '~> 5'
# Transpile app-like JavaScript. Read more: https://github.com/rails/webpacker
gem 'webpacker', '~> 4.0'
# Turbolinks makes navigating your web application faster. Read more: https://github.com/turbolinks/turbolinks
gem 'turbolinks', '~> 5'
# Build JSON APIs with ease. Read more: https://github.com/rails/jbuilder
gem 'jbuilder', '~> 2.7'
# Use Redis adapter to run Action Cable in production
# gem 'redis', '~> 4.0'
# Use Active Model has_secure_password
# gem 'bcrypt', '~> 3.1.7'

# Use Active Storage variant
# gem 'image_processing', '~> 1.2'

# Reduces boot times through caching; required in config/boot.rb
gem 'bootsnap', '>= 1.4.2', require: false

group :development, :test do
  # Call 'byebug' anywhere in the code to stop execution and get a debugger console
  gem 'byebug', platforms: [:mri, :mingw, :x64_mingw]
end

group :development do
  # Access an interactive console on exception pages or by calling 'console' anywhere in the code.
  gem 'web-console', '>= 3.3.0'
  gem 'listen', '>= 3.0.5', '< 3.2'
  # Spring speeds up development by keeping your application running in the background. Read more: https://github.com/rails/spring
  gem 'spring'
  gem 'spring-watcher-listen', '~> 2.0.0'
end

group :test do
  # Adds support for Capybara system testing and selenium driver
  gem 'capybara', '>= 2.15'
  gem 'selenium-webdriver'
  # Easy installation and use of web drivers to run system tests with browsers
  gem 'webdrivers'
end

# Windows does not include zoneinfo files, so bundle the tzinfo-data gem
gem 'tzinfo-data', platforms: [:mingw, :mswin, :x64_mingw, :jruby]
gem 'devise'
gem 'omniauth'
gem 'carrierwave'
gem 'rmagick'
gem 'jquery-rails'
gem 'jquery-ui-rails'
gem 'ransack'

試したこと

@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ページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

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

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

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

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

    詳細な説明はこちら

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

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

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

回答 2

checkベストアンサー

0

routesを見てもviewをみてもcontrollerをみても、どのようにしたいのか?
が見えない、、、、
のですが。
CACHE Post Load が何度も繰り返されるのもおかしいのですが、ここはまだ見きれて居ません。
500がでるのはもしかすると、viewの<body>が余分なのかも。
layoutにも<body>があると思うので
<head></head>
<body><body></body></body>
とbosyが重複しているのが気になります。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2019/10/24 08:00

    ご回答ありがとうございます。
    説明不足で申し訳ありません。

    home#topページからhome#searchページに飛び、レビューを検索できる仕組みを作ろうとしています。
    search_form_forでset_searchアクションを呼び出し、titleモデルからヒットしたものを表示して欲しいのですが、home#searchページに飛ぶ段階でエラーが表示されてしまっている、というのが現状です。

    ご助言いただいたbodyが重複しているという点ですが、すみません、どのファイルのことでしょうか。
    search.htm.erbのことであれば、<body></body>を消して試してみたのですが同じエラーが表示されてしまいました。。。

    キャンセル

0

開発環境ではどういう挙動やエラーが出るのですか

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2019/10/24 08:03

    知識不足なもので、ターミナルでサーバーを立ち上げていることくらいしか自分では分かりません。
    現状がすでに開発環境なのではないかと思うのですが、違うのでしょうか。。無知で申し訳ありません。

    キャンセル

  • 2019/10/24 08:08

    具体的に環境を書くと回答が得られやすいと思います。

    os
    ruby version
    rails version
    Gemfile
    database
    デプロイ場所と方法
    など
    (すべて必須ではありません)

    キャンセル

  • 2019/10/24 08:15

    Gemfileを追加させていただきました。ご確認よろしくお願いします。
    osはmacOS Mojave 10.14.5になります。

    キャンセル

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

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