0

lighttpd 1.5 の uploadprogress モジュールを動作させようとしていますが、奇妙な問題が発生しています:

アップロードを開始すると、X-Progress-ID ヘッダーが設定された状態で "/response" が毎秒呼び出されますが、応答がありません。GET 呼び出しは読み込みと読み込みを行っているだけですが、応答がありません。手動で呼び出した場合 (localhost/response?X-Progress-ID=someID)、正しいように見え、recieved と total の値が正しく設定されています。次にアップロードの進行状況をキャンセルすると (ブラウザの「X」ボタンを使用) /response が呼び出され続けますが、ステータス 200 で返されますが、もちろん、正しい値が設定されていません。

これが私のコードです:

Javascript:

 interval = null;

   function openProgressBar(uuid) {

        /* call the progress-updater every 1000ms */

        interval = window.setInterval(
             function () {
                 fetch(uuid);
              },
              1000
        );
    }

    function fetch(uuid) {
      req = new XMLHttpRequest();
      req.open("GET", "/progress", 1);
      req.setRequestHeader("X-Progress-ID", uuid);
      req.onreadystatechange = function () {
      if (req.readyState == 4) {
        if (req.status == 200) {
            /* poor-man JSON parser */
            var upload = eval(req.responseText);

            document.getElementById('tp').innerHTML = upload.state;

            /* change the width if the inner progress-bar */
            if (upload.state == 'done' || upload.state == 'uploading') {
                bar = document.getElementById('progressbar');
                w = 400 * upload.received / upload.size;
                bar.style.width = w + 'px';
            }
            /* we are done, stop the interval */
            if (upload.state == 'done') {
                window.clearTimeout(interval);
            }
        }
      }
     }
     req.send(null);
    }

そして私のHTML:

 <form id="upload" enctype="multipart/form-data" 
     action="index.php?X-Progress-ID={{tracking_id}}" 
     method="post" 
     onsubmit="openProgressBar('{{tracking_id}}'); return true;">

     <input name="video" type="file" />
     <input type="submit" class="button orange medium" value="Upload" />

 </form>

 <div>
   <div id="progress">
   <div id="progressbar"></div>
   </div>
   <div id="tp">(progress)</div>
 </div>

編集:言及するのを忘れていました... {{tracking_id}} は php コントローラーで生成され、Twig で出力されます。

4

1 に答える 1

0

Chrome の古いバグのようです。

https://code.google.com/p/chromium/issues/detail?id=45196

同じ問題..Firefoxでテストしたところ、問題なく動作しました。残念ながら、このバグは 2 ~ 3 年ほど前から存在しているため、近い将来に修正される見込みはありません。

XMLHTTPRequest を介してファイルをアップロードして動作するようになりました。

于 2013-03-06T11:45:08.900 に答える