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

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

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

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

Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Ruby on Rails

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

Q&A

解決済

1回答

1406閲覧

画像の初期投稿時、Postカラムにその#{Post.id}.jpgとしたい

tomtom1

総合スコア168

Ruby on Rails 5

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

Ruby

Rubyはプログラミング言語のひとつで、オープンソース、オブジェクト指向のプログラミング開発に対応しています。

Ruby on Rails

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

0グッド

0クリップ

投稿2018/11/16 16:09

画像をアップデートする時に、そのポストが保有するimage_name欄に、
そのポストのid.jpg(#{Post.id}.jpg)という名前を入れたいです。

Model

1=> #<Post id: 1, title: "新しい投稿", user_id: 1,image_name: "default_post.jpg",created_at: "xx", updated_at: "xx">

Post Modelは上記のようになります。

Controller

1 def create 2 @post = Post.new( 3 title: params[:title], 4 user_id: @current_user.id, 5 image_name: "default_post.jpg") 6 if @post.save 7 if params[:image_name] 8 @post.image_name = "#{@post.id}.jpg" 9 image = params[:image_name] 10 File.binwrite("public/#{@post.image_name}", image.read) 11 end 12 redirect_to("/posts/index") 13 else 14 render("posts/new") 15 end 16 end

Post Controllerは上記のようになります。
Post.newで、データを登録し、もしデータが登録された場合と続き、
if params[:image_name]では、もし画像の投稿があればというif文にしています。

上記の場合、Postのimage_nameに登録されるのが、"default_post.jpg"になります。
その部分に、"#{@post.id}.jpg"と入れると、データのセーブ前なのでかと思いますが、
undefined method `id' for nil:NilClass というエラーが出てしまいます。

Publicディレクトリ内に保存される画像の画像名はちゃんと"#{@post.id}.jpg"で保存されています。

質問内容がややこしくて申し訳ないです。
恐れ入りますが、ご教示頂ければ幸いです。

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

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

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

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

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

guest

回答1

0

ベストアンサー

Post作成前にIDは分からないのでできません
作成後に無理やり更新するならできますがIDの二重保存なので非推奨です
image_name カラムは削除してDBに保存せず、関数にするのはどうでしょう?

ruby

1class Post < ApplicationRecord 2 def image_name 3 "#{id}.jpg" 4 end 5end 6 7class PostsController < ApplicationController 8 def create 9 @post = Post.new( 10 title: params[:title], 11 user_id: @current_user.id) 12 if @post.save 13 if params[:image_name] 14 image = params[:image_name] 15 File.binwrite("public/#{@post.image_name}", image.read) 16 end 17 redirect_to("/posts/index") 18 else 19 render("posts/new") 20 end 21 end 22end

もし画像の有無を判断したい(デフォルト名なら画像なし)等の意図があるとしても
そのような仕様はバグの元なので、専用の情報として保持するべきだと思います

ruby

1if params[:image_name] 2 image = params[:image_name] 3 File.binwrite("public/#{@post.image_name}", image.read) 4 5 # 画像フラグカラムにTrueを入れる等 6 @post.update(imaged: true) 7end

投稿2018/11/19 04:02

Ighrs

総合スコア656

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

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

tomtom1

2018/11/19 05:15

ご回答ありがとうございます。 作成後に無理やり更新するならできますがIDの二重保存なので非推奨について、承知しました。また新たな方法をお教えいただきありがとうございます。 お伺いしたいのですが、それでは各投稿が保有するimage_nameカラムにはどのような名前を取り入れるのが一般的なのでしょうか? 保存された画像名にはそのポストのidがつくので、そのカラムに入る値を気にしないというのが通常なのでしょうか。 恐れ入りますが、お教え頂ければ幸いです
Ighrs

2018/11/19 05:31

1. 拡張子  jpg以外に対応するときは拡張子を保存することがあります 2. アップロードされた実際のファイル名  保存するときは idで管理するけど、ユーザーに見せるリストやダウンロード時のファイル名は本人がアップロードした名前であるべきということで、表向きのファイル名を保存することがあります  なお、その場合は image_name が2つになるので、ID付きのほうは別名にすべきでしょう
tomtom1

2018/11/19 05:40

ご丁寧にご説明ありがとうございます。 また、他の未解決の質問もございますので、 Ighrs様のお時間が許せば、ご協力頂ければ幸いです。 宜しくお願い致します。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問