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カラムを投稿しています。
最後に
調べましたが、相当する事例ブログなどが見つからず困っています!
初心者のため手解きいただけると助かります!
よろしくお願いいたします!
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2020/08/24 06:31