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

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

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

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

Q&A

2回答

271閲覧

railsでcarrierwavewp使用して画像投稿を試みたが表示されない

Aokichingo

総合スコア10

Ruby on Rails 5

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

0グッド

0クリップ

投稿2019/06/30 05:34

編集2022/01/12 10:55

20190703021554_add_image_to_post.rb

class AddImageToPost < ActiveRecord::Migration[5.0] def change add_column :posts, :image, :string end end

post.rb

class Post < ActiveRecord::Base mount_uploader :image, ImagesUploader end

show.html.erb

<div class="post"> <h1><%= @post.title %></h1> <div class="article"> <p><%= @post.description %></p> <p><%= image_tag @post.image.to_s %></p> <%= link_to 'トップへ',posts_path, class:"right" %> <%= link_to '編集',edit_post_path, class:"right" %> </div> </div>

new.html.erb

<h1>新規投稿</h1> <%= link_to 'トップへ',posts_path %> <%= form_for @post do |f| %> <p><%= f.text_field :title, placeholder: 'お名前',class:"form-control" %></p> <p><%= f.text_area :description, placeholder: '内容',class:"form-control" %></p> <%= f.file_field :image %> <p><%= f.submit class:"btn btn-info" %></p> <% end %>

post_controller.rb

class PostsController < ApplicationController def index @posts = Post.all.order(created_at:'desc') end def show @post= Post.find(params[:id]) end def new @post = Post.new end def edit @post = Post.find(params[:id]) end def create @post = Post.new(post_params) @post.save flash[:notice] = "タスク「#{@post.title}」を登録しました。" redirect_to "/" end def update @post = Post.find(params[:id]) @post.update!(post_params) flash[:notice] = "タスク「#{@post.title}」を編集しました。" redirect_to "/" end def destroy @post = Post.find(params[:id]) @post.destroy flash[:notice] = "タスク「#{@post.title}」を削除しました。" redirect_to "/" end private def post_params params.require(:post).permit(:title,:description) end end

image_uploader.rb

class ImagesUploader < CarrierWave::Uploader::Base # Include RMagick or MiniMagick support: # include CarrierWave::RMagick # include CarrierWave::MiniMagick # Choose what kind of storage to use for this uploader: storage :file # storage :fog # Override the directory where uploaded files will be stored. # This is a sensible default for uploaders that are meant to be mounted: def store_dir "uploads/#{model.class.to_s.underscore}/#{mounted_as}/#{model.id}" end # Provide a default URL as a default if there hasn't been a file uploaded: # def default_url(*args) # # For Rails 3.1+ asset pipeline compatibility: # # ActionController::Base.helpers.asset_path("fallback/" + [version_name, "default.png"].compact.join('_')) # # "/images/fallback/" + [version_name, "default.png"].compact.join('_') # end # Process files as they are uploaded: # process scale: [200, 300] # # def scale(width, height) # # do something # end # Create different versions of your uploaded files: # version :thumb do # process resize_to_fit: [50, 50] # end # Add a white list of extensions which are allowed to be uploaded. # For images you might use something like this: # def extension_whitelist # %w(jpg jpeg gif png) # end # Override the filename of the uploaded files: # Avoid using model.id or version_name here, see uploader/store.rb for details. # def filename # "something.jpg" if original_filename # end end

以上がコードです。

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

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

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

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

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

gentaro

2019/06/30 09:46

https://teratail.com/help/question-tips 「teratailはサポートセンターではなく、思考するエンジニアの為のQ&Aコミュニティです」 そのエラーが出るまでに何を行ったのか、関連する全てのコードはどのようなものなのか、ちゃんと書かないと誰も答えられません。
Aokichingo

2019/07/08 07:11

該当コードを全て載せました。 以上でエラーは出ないものの画像が表示されません。 お確認お願いします。
Aokichingo

2019/07/08 07:13

rails consoleから Post.allで確認したところ => #<ActiveRecord::Relation [#<Post id: 1, title: "rgs", description: "gsg", created_at: "2019-07-03 02:18:41", updated_at: "2019-07-03 02:18:41", image: nil>, #<Post id: 2, title: "kjnlij", description: "j l", created_at: "2019-07-03 02:21:17", updated_at: "2019-07-03 02:21:17", image: nil>, #<Post id: 6, title: "bvk", description: "liyfli", created_at: "2019-07-03 02:29:29", updated_at: "2019-07-03 02:29:29", image: nil>, #<Post id: 7, title: "wevwe", description: "ewrfwe", created_at: "2019-07-03 02:35:30", updated_at: "2019-07-03 02:35:30", image: nil>, #<Post id: 8, title: "ss", description: "iygliy", created_at: "2019-07-03 02:36:56", updated_at: "2019-07-03 02:36:56", image: nil>, #<Post id: 9, title: "zrgazr", description: "fhaz", created_at: "2019-07-08 07:10:07", updated_at: "2019-07-08 07:10:07", image: nil>]> 2.6.3 :002 > imageがnilになります。
winterboum

2019/07/08 07:55

モデル Post の uploader 宣言部を。
Aokichingo

2019/07/10 02:09

post.rb class Post < ActiveRecord::Base mount_uploader :image, ImagesUploader ここで間違いはないでしょうか? end
guest

回答2

0

ああ、ここかな

def post_params params.require(:post).permit(:title,:description) end

logに、image が unpermittedだって出てませんか?
permit(:title,:description,:image)
で試してみて下さい

投稿2019/07/10 02:47

winterboum

総合スコア23284

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

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

0

提供されている情報からは、エラーが起きるとは思えません。
エラーメッセージはその1行だけですか?
全部見せて下さい。
それだけであった場合、--trace オプション(だったかな)をWつけると冗長なエラーが出ますので、それを

投稿2019/07/01 05:25

winterboum

総合スコア23284

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

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

Aokichingo

2019/07/08 07:15

質問内容を大幅に変更しました。 上記のコードでrails consoleからPost.allを見たところ => #<ActiveRecord::Relation [#<Post id: 1, title: "rgs", description: "gsg", created_at: "2019-07-03 02:18:41", updated_at: "2019-07-03 02:18:41", image: nil>, #<Post id: 2, title: "kjnlij", description: "j l", created_at: "2019-07-03 02:21:17", updated_at: "2019-07-03 02:21:17", image: nil>, #<Post id: 6, title: "bvk", description: "liyfli", created_at: "2019-07-03 02:29:29", updated_at: "2019-07-03 02:29:29", image: nil>, #<Post id: 7, title: "wevwe", description: "ewrfwe", created_at: "2019-07-03 02:35:30", updated_at: "2019-07-03 02:35:30", image: nil>, #<Post id: 8, title: "ss", description: "iygliy", created_at: "2019-07-03 02:36:56", updated_at: "2019-07-03 02:36:56", image: nil>, #<Post id: 9, title: "zrgazr", description: "fhaz", created_at: "2019-07-08 07:10:07", updated_at: "2019-07-08 07:10:07", image: nil>]> 2.6.3 :002 > imageがnilになります。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問