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

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

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

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

Ruby on Rails 4

Ruby on Rails4はRubyによって書かれたオープンソースのウェブフレームワークです。 Ruby on Railsは「設定より規約」の原則に従っており、効率的に作業を行うために再開発を行う必要をなくしてくれます。

Ajax

Ajaxとは、Webブラウザ内で搭載されているJavaScriptのHTTP通信機能を使って非同期通信を利用し、インターフェイスの構築などを行う技術の総称です。XMLドキュメントを指定したURLから読み込み、画面描画やユーザの操作などと並行してサーバと非同期に通信するWebアプリケーションを実現することができます。

Q&A

解決済

3回答

4560閲覧

Ajaxで画像データのPostについて

GOROGORO

総合スコア66

Ruby on Rails

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

Ruby on Rails 4

Ruby on Rails4はRubyによって書かれたオープンソースのウェブフレームワークです。 Ruby on Railsは「設定より規約」の原則に従っており、効率的に作業を行うために再開発を行う必要をなくしてくれます。

Ajax

Ajaxとは、Webブラウザ内で搭載されているJavaScriptのHTTP通信機能を使って非同期通信を利用し、インターフェイスの構築などを行う技術の総称です。XMLドキュメントを指定したURLから読み込み、画面描画やユーザの操作などと並行してサーバと非同期に通信するWebアプリケーションを実現することができます。

0グッド

1クリップ

投稿2015/05/06 13:49

こんにちは。

Rails4、Ajaxで非同期に画像を登録する処理を作成しています。
formで画像が選択されたことをAjaxで検知して、controllerへPostしたいです。

以下のようにコードを書いています。

lang

1<!--画像登録用ボタン--> 2<input type="file" accept="image/*" id="imputImage" /> 3 4 5<!-- 画像登録用JS --> 6<script> 7 $(function() { 8 $('#imputImage').change(function() { 9 var fd = new FormData($('#imputImage').get(0)); 10 $.ajax({ 11 url : '/blog_images', 12 type : "POST", 13 data : fd, 14 processData : false, 15 contentType : false, 16 }); 17 }); 18 }); 19</script>

ですが、上記の状態でformで画像を選択しても500エラーとなります。

サーバ側のログは以下の通りです。

lang

1[2015-05-06 13:39:51] ERROR EOFError: bad content body 2 /opt/ruby/lib/ruby/gems/2.1.0/gems/rack-1.5.2/lib/rack/multipart/parser.rb:74:in `block in fast_forward_to_first_boundary' 3 /opt/ruby/lib/ruby/gems/2.1.0/gems/rack-1.5.2/lib/rack/multipart/parser.rb:72:in `loop' 4 /opt/ruby/lib/ruby/gems/2.1.0/gems/rack-1.5.2/lib/rack/multipart/parser.rb:72:in `fast_forward_to_first_boundary' 5 /opt/ruby/lib/ruby/gems/2.1.0/gems/rack-1.5.2/lib/rack/multipart/parser.rb:15:in `parse' 6 /opt/ruby/lib/ruby/gems/2.1.0/gems/rack-1.5.2/lib/rack/multipart.rb:25:in `parse_multipart' 7 /opt/ruby/lib/ruby/gems/2.1.0/gems/rack-1.5.2/lib/rack/request.rb:377:in `parse_multipart' 8 /opt/ruby/lib/ruby/gems/2.1.0/gems/rack-1.5.2/lib/rack/request.rb:203:in `POST' 9 /opt/ruby/lib/ruby/gems/2.1.0/gems/rack-1.5.2/lib/rack/methodoverride.rb:26:in `method_override' 10 /opt/ruby/lib/ruby/gems/2.1.0/gems/rack-1.5.2/lib/rack/methodoverride.rb:14:in `call' 11 /opt/ruby/lib/ruby/gems/2.1.0/gems/rack-1.5.2/lib/rack/runtime.rb:17:in `call' 12 /opt/ruby/lib/ruby/gems/2.1.0/gems/activesupport-4.1.4/lib/active_support/cache/strategy/local_cache_middleware.rb:26:in `call' 13 /opt/ruby/lib/ruby/gems/2.1.0/gems/rack-1.5.2/lib/rack/lock.rb:17:in `call' 14 /opt/ruby/lib/ruby/gems/2.1.0/gems/actionpack-4.1.4/lib/action_dispatch/middleware/static.rb:64:in `call' 15 /opt/ruby/lib/ruby/gems/2.1.0/gems/rack-1.5.2/lib/rack/sendfile.rb:112:in `call' 16 /opt/ruby/lib/ruby/gems/2.1.0/gems/railties-4.1.4/lib/rails/engine.rb:514:in `call' 17 /opt/ruby/lib/ruby/gems/2.1.0/gems/railties-4.1.4/lib/rails/application.rb:144:in `call' 18 /opt/ruby/lib/ruby/gems/2.1.0/gems/rack-1.5.2/lib/rack/lock.rb:17:in `call' 19 /opt/ruby/lib/ruby/gems/2.1.0/gems/rack-1.5.2/lib/rack/content_length.rb:14:in `call' 20 /opt/ruby/lib/ruby/gems/2.1.0/gems/rack-1.5.2/lib/rack/handler/webrick.rb:60:in `service' 21 /opt/ruby/lib/ruby/2.1.0/webrick/httpserver.rb:138:in `service' 22 /opt/ruby/lib/ruby/2.1.0/webrick/httpserver.rb:94:in `run' 23 /opt/ruby/lib/ruby/2.1.0/webrick/server.rb:295:in `block in start_thread'

正しくhttpリクエストを作成できていないのではないかと思っていのですが、どうしてよいものかいきづまってしまい。。。
お教えいただけると幸いです。
よろしくお願いします。!!

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

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

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

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

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

guest

回答3

0

やり方いろいろあるとおもいますが、
formを使うのであれば、form属性にmultipartをつけないとファイルは送れないです。

こんなかんじですね。
<%= form_for(@image,
url: upload_image_path,
html: {multipart: true},
remote: true) do |image| %>

投稿2015/05/07 15:52

ylang365

総合スコア175

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

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

0

ベストアンサー

しばらくPHP でのアップロードを試していましたが、jQuery 標準のAjax での送信はできませんでした(同様のエラーが出ました)
jQuery Form Plugin のajaxSubmit() で動作させることが出来ました

以下Rails 用に書き換えてみました

前提:

  • アップロード機能にCarrierwave
  • 新規作成からrails g scaffold user name:string image:string
  • テンプレートエンジン Slim
  • CoffeeScript

(適宜読み替えをお願いします)

ファイルの編集

app/views/layouts/application.html.slim :

/form プラグインの読み込みを追加 = javascript_include_tag "http://malsup.github.com/jquery.form.js", 'data-turbolinks-track' => true

app/views/users/new.html.slim :

h1 New user /== render 'form' /#new_user が挿入された状態で展開される = form_for @user do |f| p = f.label :name, 'Name' = f.text_field :name p = f.label :image, 'Image' = f.file_field :image /#user_image が挿入された状態で展開される p = f.submit = link_to 'Back', users_path

app/assets/javascripts/users.new.coffee :

# @ == this 相当 # $(document).ready(function () {}) $ -> $('#new_user #user_image').on 'change', -> console.log('on submit') # debug print $(@).submit() $('#new_user').on 'submit', (e) -> e.preventDefault() $(@).ajaxSubmit() console.log('ajaxSubmit') # debug print

動作確認

Rails server を立ち上げて、localhost:3000/users/new にアクセスし、ファイルを選択する

以上 何か参考になれば幸いです

Link

投稿2015/05/07 02:04

編集2015/05/07 02:08
gouf

総合スコア2321

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

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

GOROGORO

2015/05/07 10:02

ありがとうございます!! jQuery Form Pluginを使ってPost送ることができました!! こんなのあるのですね。。。 はじめて知りました。
guest

0

画像の場合は、下記で行けると思います。

lang

1data: { 2 'file': fd.val() 3},

投稿2015/05/06 22:47

IizukaYasushi

総合スコア19

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問