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

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

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

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

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

Q&A

1回答

5697閲覧

ダウンロードアップロード中の進捗表示

退会済みユーザー

退会済みユーザー

総合スコア0

Ruby on Rails

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

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

0グッド

0クリップ

投稿2018/10/25 04:04

編集2018/11/01 09:57

Rails でファイルのインポートやダウンロードのついたシステムを開発中なのですが
サイズの大きいファイルのダウンロードやアップロード中
左下に localhost を待機しています
とでるだけで本当に処理がすすんでるのかどうかわかりにくいです

途中で進捗報告を表示して画面を更新するにはどのような機構を使えばいいのでしょうか

ダウンロードボタンと同時にクライアントで JS を起動しておいて
一定時間ごとにサーバーに進捗を問い合わせて結果で画面のDOMを更新
みたいな方法しか思いつかないのですが
どの接続がどの進捗をほしがってるのか対応をとるのも大変そうだし
普通はどのような方法を使うのでしょうか

追記:

ファイルインポート・エクスポートに進捗報告をつける方法をずっと調べていたんですが
Rails でコントローラーが処理中に進捗報告等の別のリクエストに返答を行いたい場合
非同期処理についていろいろ調べたのですがどれも別のジョブサーバーを立ててキューを保存するらしく
本当にそんなことまでしないと進捗報告というのは実現できないのでしょうか

Apache では普通に別リクエストには別のプロセスがわりあてられて
同時処理してくれる気がするのですがRailsでできないのは何か理由があるのでしょうか

別にサーバーをたてるとなるとリソースやキューのモニターやログの監視も必要になるし
同じクラウドのマシン上で動かすとリソースも問題になるし
とくにいずれもアップロードしたファイルや生成したダウンロードファイルをジョブサーバーとコントローラーでやりとりしなければいけないので非常に無駄な気がするのです

学生時代に習った低レベルのTCPソケット通信であればインポートの場合
アップロードリクエストをうけとったら進捗メッセージを徐々に返して
それをJSでゆっくりよめばいいだけだし
エクスポートでも準備中に少しずつ進捗メッセージを返して
準備完了メッセージを返したらそれ以降をダウンロードデータとみなすみたいにすれば
1度のリクエスト+レスポンスだけで実現できる気がするのですが今のウェブ技術では不可能なのでしょうか

一応少しずつレスポンスしたりそれをよんだりするのはSSEやFETCHという技術でできるみたいなのですが
どちらもテストコードをかいて通信するところまではできたのですが
POSTでリクエストを送ってそのままそのコネクションを使ってレスポンスをストリームでうけるというのができないみたいで…
そうなると別のコントローラーを叩くことになっていずれにしろRailsに並列処理が求められます

追記

Rails:

self.response_body = Rack::Chunked::Body.new(Enumerator.new do |y|

参考: http://ode.hatenadiary.jp/entry/20120123/1327301403

javascript:

fetch() .then((response) => response.body.getReader()) .then((reader) => {}

参考: https://sbfl.net/blog/2018/05/26/javascript-streams-api/

でファイルアップロードリクエストの後レスポンスをストリームでうけとれるようにできました
ただせっかく実装して動作までしたのに今回の案件の動作環境にはいっていたIE11がFetchに非対応だったのでまた別の方法が必要みたいです…

IE11で動くJS側でレスポンスを途中で読む方法はないでしょうか…

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

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

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

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

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

guest

回答1

0

ベストな方法かわかりませんがご参考までに。

ダウンロードのリクエストを投げると同時に以下のsetIntervalをおこなって
レスポンスを待ち受けるという方法は使った経験があります。

ダウンロードファイルのレスポンスヘッダーにCookie「downloaded=yes」ををセットするようにして
ファイルがダウンロードできたと同時に完了が検知できます。
開始のエフェクトで砂時計をだして完了のエフェクトで表示を消すイメージです。

javascript

1 2//開始のエフェクト 3 4downloadLoadingTimer = setInterval(function () { 5 var cookieData = getCookies(); 6 var downloadCookie = cookieData["downloaded"]; 7 if(downloadCookie != undefined && downloadCookie == "yes"){ 8 setCookies("downloaded", "no"); 9 clearInterval(downloadLoadingTimer); 10 // c4s.sleep(2500); 11 12 //完了のエフェクト 13 } 14 }, 100); 15 16function getCookies() { 17 var result = new Array(); 18 var cookies = document.cookie; 19 { 20 var cookiesArray = cookies.split( '; ' ); 21 for( var i = 0; i < cookiesArray.length; i++ ) 22 { 23 var cookie = cookiesArray[ i ].split( '=' ); 24 result[ cookie[ 0 ] ] = decodeURIComponent( cookie[ 1 ] ); 25 } 26 } 27 return result; 28 } 29 30function setCookies(key, value) { 31 var expire = new Date(); 32 expire.setTime( expire.getTime() + 1000 * 3600 * 24 * 365 * 100 ); 33 document.cookie = key + '=' + encodeURIComponent(value) + '; expires=' + expire.toUTCString() + ';path=/'; 34 },

あとはそもそも同じようなことを質問している方がいましたのでそちらも参考になるかと
https://teratail.com/questions/82898

投稿2018/10/25 10:15

編集2018/10/25 10:22
miyasaka

総合スコア271

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

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

退会済みユーザー

退会済みユーザー

2018/10/25 10:27 編集

ありがとうございます 最後にはっていただいたリンクをすでに教えていただいていて そこを参考にしてずっと試行錯誤してレスポンス完了時にJSを実行できるようにはなったんですが AJAXでリクエストを送ると肝心のダウンロードが行われなくて途方にくれてたところでした クッキーを扱うのもはじめてなんですが他に手段がなくてこまってたので試してみたいと思います ありがとうございます
退会済みユーザー

退会済みユーザー

2018/11/01 10:01

今回の案件では指定されていないのですがクライアントに官庁系が入ったりするとクッキーを使えないことがあるみたいで、できれば汎用的に使いませるようにクッキーを使わない方法を知りたいです せっかく回答いただいたのに申し訳ありません ちなみにリンク先の記事をよんでみたんですがどうもダウンロードアップロード自体にはファイルサイズをみて進捗を取得するイベントが存在していて簡単にかけるみたいですね 試しにつけてみたのですが一瞬で終わってしまって 今回時間がかかるのはダウンロード前のファイルの準備やアップロード後のインポート処理みたいなので Rails 側から進捗を受け取るしか方法がないみたいです
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問