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

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

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

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

MySQL

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

Ruby on Rails

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

jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

Amazon S3

Amazon S3 (Simple Storage Service)とはアマゾン・ウェブ・サービスが提供するオンラインストレージサービスです。

Q&A

解決済

1回答

1058閲覧

Railsでできていた画像投稿ができなくなった

Lindsey

総合スコア1

Ruby

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

MySQL

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

Ruby on Rails

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

jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

Amazon S3

Amazon S3 (Simple Storage Service)とはアマゾン・ウェブ・サービスが提供するオンラインストレージサービスです。

0グッド

0クリップ

投稿2020/08/21 15:29

編集2020/08/21 15:36

Railsで画像投稿ができなくなった

###環境
Ruby 2.5.1
Rails 5.2.3

###ー問題点ー

・画像のmysqlへの保存ができなくなってしまった 
(controller/create投稿画像(image)とdevise/registration/newユーザーアイコン(avatar))

・画像投稿時にJqueryでプレビューを表示していましたが、プレビューの機能をコメントアウトすると保存ができる

(readAsDataURlでエンコードされているため保存できなのか?と思いましたが、以前はできていたのにいきなりできなくなってしまった理由がわかりません)

###ー経緯ー
作成中ポートフォリオの画像保存先をS3に変更しようとしていてymlなどを変更していた

開発環境とテスト環境での画像の保存先はローカルのpublicをと条件分岐をしていたのにも関わらず保存ができていない

debugしてみると画像をしている画像が入っていないとのエラーでロールバックが起こっている状態

画面はcreate後redirectされ動いていますが保存がされておらず、
何故かJqueryのプレビュー機能部分をコメントアウトをし、投稿すると以前通り保存ができる

※deviseを使用しての新規登録時のアイコン(avatar)は
configure_permitted_parametersに追加済
※strong prametersにimageも追加済

//ターミナルでのロールバック Processing by PostsController#create as HTML Parameters: {"utf8"=>"✓", "authenticity_token"=>"VsnuK3JoaOvnBlXkw9PZwaQtpejusOqPJjbyVw8u1DUghgnqfWW5e8TZtgvEsctM1EwoQ8VSBEt1++jqw0jEKg==", "post"=>{"title"=>"BTS♩", "country"=>"韓国", "city"=>"", "how"=>"", "discription"=>"111"}, "commit"=>"投稿"} (1.8ms) BEGIN ↳ app/controllers/posts_controller.rb:16 (0.2ms) ROLLBACK ↳ app/controllers/posts_controller.rb:16 (0.2ms) BEGIN ↳ app/controllers/posts_controller.rb:18 (0.1ms) ROLLBACK ↳ app/controllers/posts_controller.rb:18
//logger.debugでのエラー文 #<ActiveModel::Errors:0x00007fa716882330 @base=#<Post id: nil, city: "", how: "", discription: "111", created_at: nil, updated_at: nil, like_count: nil, title: "BTS♩", country: "韓国", user_id: 1, image: nil>, @messages={:image=>["can't be blank"]}, @details={:image=>[{:error=>:blank}]}>

###コード

controller

1 def new 2 @post = Post.new 3 4 end 5 6 def create 7 @post = current_user.posts.create(post_params) 8 @post.save 9 redirect_to posts_path 10 # logger.debug @post.errors.inspect 11 end 12 13 private 14 def post_params 15 params.require(:post).permit(:image, :title, :country, :city, :how, :discription, :like_count) 16 end 17 18 19

jquery

1$(function () { 2 $('form').on('change', 'input[type="file"]', function (e) { 3 var file = e.target.files[0], 4 reader = new FileReader(), 5 $preview = $(".preview"); 6 7 if (file.type.indexOf("image") < 0) { 8 return false; //一致するものがなければfalse 9 } 10 11 reader.onload = (function (file) { 12 return function (e) { 13 $preview.empty(); //空の状態にする 14 $preview.append($('<img>').attr({ //属性をpreviewのimgに追加 15 src: e.target.result, //取得した結果 16 width: "250px", 17 height: "250px", 18 class: "preview", 19 title: file.name 20 })); 21 }; 22 })(file); 23 24 reader.readAsDataURL(file); //ファイル読み込み 25 }); 26}); 27

new controllerでプレビューを表示する投稿画面

form

1 .main 2 -# .main__right 3 = form_for(@post, url: posts_path) do |f| 4 .preview 5 = f.label :image, for: "upload-image", class: "image-preview" do 6 - if @post.image.url.present? 7 = image_tag @post.image.url, alt: "preview", class: "preview-image" 8 -else 9 = icon('fa', 'camera') 10 = f.file_field :image, class: "hidden", id: "upload-image" 11

試したこと

・最初はS3のために変更した部分に問題があるのかと思い、変更した部分をコメントアウトして試していましたがそれでもダメだったので、保存先をローカルに戻しましたがダメでした。

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

・CarrierWaveでPost(投稿)モデルのimageカラムとUserモデルのavatarカラムを投稿しています。


最後に
調べましたが、相当する事例ブログなどが見つからず困っています!
初心者のため手解きいただけると助かります!
よろしくお願いいたします!

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

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

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

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

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

guest

回答1

0

ベストアンサー

paramsからimageが消えているので、プレビューの表示によりinputが消えていませんか?

おそらく下記の処理がまずいです。

js

1$preview.empty(); //空の状態にする

ここでinputも削除してしまっているので、
inputを.preview の外に出して処理を書き直せばできると思います。

投稿2020/08/22 03:34

Cojiro

総合スコア539

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

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

Lindsey

2020/08/24 06:31

kojiro12345様> ご指摘ありがとうございます! ご指摘通り、プレビュー後保存ができるようになりました! ありがとうございます!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.46%

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

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

質問する

関連した質問