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

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

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

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

Ruby on Rails

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

Q&A

解決済

1回答

1051閲覧

画像が表示されない ruby on rails

topposan2zi

総合スコア5

MySQL

MySQL(マイエスキューエル)は、TCX DataKonsultAB社などが開発するRDBMS(リレーショナルデータベースの管理システム)です。世界で最も人気の高いシステムで、オープンソースで開発されています。MySQLデータベースサーバは、高速性と信頼性があり、Linux、UNIX、Windowsなどの複数のプラットフォームで動作することができます。

Ruby on Rails

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

0グッド

0クリップ

投稿2020/07/10 10:25

前提・実現したいこと

新規投稿をして画像をdbに保存し、保存したものを表示さたい
ここに質問の内容を詳しく書いてください。
(例)PHP(CakePHP)で●●なシステムを作っています。
■■な機能を実装中に以下のエラーメッセージが発生しました。

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

post.nameは表示されているが、post.imageが表示されない

エラーメッセージ

該当のソースコード

index.html.erb <div class="wrapper"> <div class="main"> <div class="contents"> <% @posts.each do |post| %> <div class="contents__image" style="background-image: url(<%= post.image %>);"> <span class="name"> <%= post.name %> </span> </div> <% end %> </div> </div> </div> posts_controller.rb class PostsController < ApplicationController def index @posts = Post.all.order("created_at DESC") end def new @post = Post.new end def create @post = Post.create(post_params) @post.save redirect_to :root end private def post_params params.require(:post).permit(:text, :image, :name).merge(user_id: current_user.id) end end

試したこと

ここに問題に対して試したことを記載してください。
post.nameと同じようにして表示してみるとimageの中身が#ActionDispatch::Http::UploadedFile:0x00007ff607783ea8というような記述になり調べた結果今の記述で表示されているものがあったので真似してみたが表示されなかった。

補足情報(FW/ツールのバージョンなど)

ここにより詳細な情報を記載してください。

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

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

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

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

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

guest

回答1

0

ベストアンサー

ActionDispatch::Http::UploadedFile はあまり取り回したことがないのですが、CSSで画像を指定する場合などはアップロードした画像の実体がサーバ上のどこかにある必要があります。

ActionDispatch::Http::UploadedFile はドキュメントを読む限りDB内にファイルのバイナリを保存しているように思います。Rails側がファイルをホスティングはしていないのではないでしょうか。(間違えていたらすみません)
https://api.rubyonrails.org/v6.0.3.2/classes/ActionDispatch/Http/UploadedFile.html

強引にやるとしたら、 read メソッドでファイルのバイナリを読み込むことができるので、BASE64にエンコードしてDATA URLで埋め込むというのができるかと思います。
https://developer.mozilla.org/ja/docs/Web/HTTP/Basics_of_HTTP/Data_URIs

試していないですが、以下のコードでひとまず表示は出来るかもしれません。
<div class="contents__image" style="background-image: url(data:image/png;base64,<%= Base64.encode64(post.image.read) %>);">

投稿2020/07/10 13:19

yuki-yano

総合スコア132

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

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

topposan2zi

2020/07/11 23:39

回答ありがとうございます! 詳しく調べたところ今の記述だとurlの状態の画像しか表示できないみたいでした。 carrierwaveを使ってjpgでdbに保存してimage_tagでやってみようと思います! 調べていただきありがとうございました!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問