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

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

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

HerokuはHeroku社が開発と運営を行っているPaaSの名称です。RubyやNode.js、Python、そしてJVMベース(Java、Scala、Clojureなど)の複数のプログラミング言語をサポートしている。

Ruby on Rails

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

Q&A

解決済

1回答

546閲覧

heroku × Cloudinaryの使用方法

Gr.

総合スコア89

Heroku

HerokuはHeroku社が開発と運営を行っているPaaSの名称です。RubyやNode.js、Python、そしてJVMベース(Java、Scala、Clojureなど)の複数のプログラミング言語をサポートしている。

Ruby on Rails

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

0グッド

1クリップ

投稿2019/02/09 11:50

編集2019/02/10 00:08

Herokuにデプロイしたアプリでは、アップロードした画像がpushするたびに消えてしまうため、外部のデータベースを用意してそちらに画像を保存する必要があるらしい。

そこでherokuと親和性が良いCloudinaryを使って画像をアップすることにしました。

前提

Railsで練習用アプリを作成しています。アプリというよりホームページに近いかもしれませんが。

100件の本のデータを入れ、indexで一覧表示、showで各本の詳細を表示します。

showで詳細に飛んだ時、その本のカバーを画像で表示させようと思います。

Viewのbooks/newの画面にデータ入力フォームを設け、アプリ上でデータの登録をするとします。
画像アップロードに関しては<%= f.attachment_field :image %>で実装しています。

books/new.html.erb

html

1<%= form_for(@book) do |f| %> 2<table> 3 <tr> 4  <td><%= f.attachment_field :image %></td> 5 </tr> 6 <tr> 7  <td><%= f.text_field :image_title, placeholder: '画像のタイトル' %></td> 8 </tr> 9 <tr> 10  <td><%= f.text_field :title, placeholder: '本のタイトル' %></td> 11 </tr> 12 <tr> 13  <td><%= f.text_field :year, placeholder: '出版年' %></td> 14 </tr> 15  :

このようなフォームで本のタイトルや出版年、カバー画像などを登録し、Viewのbooks/showでその本のデータを表示します。

books/show.html.erb

html

1<table> 2 <tr> 3  <td><%= @book.title %></td> 4 </tr> 5 <tr> 6  <td><%= attachment_image_tag @book, :image, :title => @book.image_title %></td> 7 </tr> 8  :

Bookモデルには以下のように記述し、Booksコントローラのストロングパラメータに:image, :image_titleを入れています。

book.rb

model

1attachment :image

books_controller.rb

controller

1private 2 def book_params 3  params.require(:book).permit(:image, :image_title, ... 4 end 5end

開発環境(ローカル)では、これで問題なく画像が表示されます。

本題

このアプリをherokuにデプロイし、DBが変わったので改めて何件かのデータをbooks/newの画面から入力したところ、初めは何も問題なく表示されたのですが、再度pushしたところ画像のデータだけが消えてしまいました。

そこで、冒頭でも触れましたが、外部のデータベースを用意してそちらに画像を保存することにしました。

以下の手順を踏んで再度フォームから画像を登録したのですが、変化ありません。
画像が結局Cloudinaryに保存されないのですが、あと何をすればいいのでしょうか。

  1. herokuにCloudinaryのアドオンを追加し
  2. Cloudinaryの登録を済ませ使えるようにし
  3. Railsのconfig以下にダウンロードしたcloudinary.ymlを入れ
  4. 通常のadd ~ pushの手順でpushした

アプリ上で画像を投稿してもCloudinaryに保存されずやはり消えてしまいます。
経験のある方、詳しい方、ぜひご教授願います。

gem 'cloudinary'

を入れる、と書いている人もいたのですが、入れてbundle installしたら、そんなgemは無いとエラーが返ります。

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

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

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

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

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

kabao

2019/02/09 16:28

CloudinaryのAPIを利用する部分のソースコードを貼り付けた方がいいと思いますよ。
Gr.

2019/02/10 00:11

kabaoさん 質問への追記・修正の依頼、ありがとうございます。 >CloudinaryのAPIを利用する部分のソースコード 知識が浅くてよくわからなかったので、画像投稿機能の周辺をおおまかに追記しました。 足りないことがあれば仰ってください。
kabao

2019/02/10 02:02

CloudinaryのAPIを呼んで、Cloudinaryにアップロードする処理を書く必要があるのですが、そのソースコードが無いですね。 railsの場合、CarrierWaveというライブラリを使うとアップロード処理を簡単に実装出来て、CariierWaveとCloudinaryのAPIを組み合わせるのがおすすめみたいです。 まずはこのあたりを参考にアップロード処理を作ってみるのがいいんじゃないでしょうか。 https://cloudinary.com/documentation/rails_integration https://github.com/cloudinary/cloudinary_gem/tree/master/samples/photo_album https://qiita.com/GenTamura84/items/38cf899827bba050a21c
Gr.

2019/02/10 02:27

kabaoさん 返答ありがとうございます。 参考リンクを見てみると、画像のアップローダーとして新たにモデルを作り既存のモデルと関連付けているようで、たしかにこの機能を実装していませんでした。 GemにCarrierWaveの後継とされるRefileを入れているので、まずはそちらを使ってアップロード処理を実装してみます。
Gr.

2019/02/10 02:36 編集

kabaoさん ちなみにですが、 >CloudinaryのAPIを呼んで、Cloudinaryにアップロードする処理を書く のは、どのファイルに書くのでしょうか。 参考として貼っていただいたリンクのうち3番目のページhttps://qiita.com/GenTamura84/items/38cf899827bba050a21c でいうと、どこに書かれているのでしょうか。 「avatar_uploader.rbを編集」という見出しの、app/avatar_uploader.rb というコードに書かれた include Cloudinary::CarrierWave の部分ですか? 繰り返し失礼いたします。
kabao

2019/02/10 07:50

はい、基本的にはavatar_uploaderの中から呼んでいるということになりますね。 実際にはavater_uploaderには直接的には記載されていませんが、CarrierWave::Uploader::Baseを継承していることと、Cloudinary::CarrierWaveをincludeしていることで、内部的に呼び出されているということになります。
guest

回答1

0

ベストアンサー

まずはCarrierWaveかRefileなどを使ってuploaderの処理を作って、そこでCloudinaryが呼ばれるようにしてくださいということですね。

投稿2019/02/10 06:47

kabao

総合スコア648

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問