2013-03-02 222 views
3

我发现HTTP PUT请求IST最适合非常大的文件上传(1GB或更多)。HTTP PUT请求 - 进度条实施

解决方案的工作很好,我可以上传我的选择的任何文件到服务器。但是,我在监视上传过程中遇到困难。

我已经实现了onprogress回调,但是这个只有在通过PUT上传文件后才被调用。

我的JavaScript代码:

var req = createRequest(); 
req.open("PUT", "PHP/upload_file.php?folder=" + aUploadedFile.upload_folder + "&master_folder=" + settings.strServerSideMasterFolder + "&file_name=" + aUploadedFile.file_name); 
req.setRequestHeader("Content-type", "text/plain"); 
req.onload = function (event) 
{ 
    console.log("OnLoad Called: " + aUploadedFile.file_name); 
} 
req.onprogress = function (event) 
{ 
    console.log("OnProgress Called: " + aUploadedFile.file_name); 
} 
req.send(aUploadedFile.file_object); 
  • 什么是我的选择,当我想通过监测PUT上传进度,好吗?
  • 我应该建立另一个JavaScript AJAX调用,将监视上传的文件○服务器的大小?
  • 是否有其他可用的工作解决方案?

我用:

  • HTML5
  • 的JavaScript
  • PHP
  • 阿帕奇

我不使用:

  • jQuery的

预先感谢您。

+0

你见过这个吗? http://stackoverflow.com/questions/49564/how-to-implement-file-upload-progress-bar-on-web – 2013-03-02 12:54:16

+1

@JohnZwinck:嗨。感谢您的评论。我的问题可能非常具体?您的链接显示了进度条的各种实现,但它们中没有一个与HTTP PUT请求相关。为HTTP POST请求创建进度条相当简单,但问题是**相同的代码不适用于HTTP PUT请求**。 – 2013-03-02 13:00:20

+0

你为什么不回避POST? – 2013-03-02 13:57:16

回答

4

你试过xhr.upload.onprogress而不是xhr.onprogress

如果这不起作用,您可以建立另一个JavaScript AJAX调用,就像您说的那样。最近,我制作了一个上传系统,每行读取文件行,它需要显示一些关于上传的额外信息,而不仅仅是百分比,所以我做了这样的事情:

  • 主要第一个Ajax请求,负责处理文件
  • 在该文件中的文件时,我不得不关闭连接,所以AJAX请求能够完成,但PHP脚本将仍然运行,使用这样的:
ob_start(); 
$file = tempnam('/tmp', uniqid()); // create a temp file to show status of the action 
echo json_encode(array('file' => $file)); 
header('Content-length: '.ob_get_length()); 
header('Connection: close'); 
ob_end_flush(); 
flush(); // The AJAX request is completed here, but the script is still running... 

function writeToFile($handle, $arr) { 
    ftruncate($handle, 0); // empty file 
    fwrite($handle, json_encode($arr)); 
} 
$handle = fopen($file, 'w'); 
while (readLine($uploadedFile)) { 
    // code to process line 
    writeToFile($handle, array('progress' => $current/$total, 'action' => 'Reading...')); 
} 
// insert into database 
writeToFile($handle, array('progress' => '100', 'action' => 'Inserting into database...')); 
fclose($handle); 
  • 在主页面,AJAX请求将返回一个包含信息的文件的名称,所以我会创建多个GET请求到该文件,使用setInterval方法

注:在我的情况,我创建了另一个PHP文件来显示进度文件的内容(使用file_get_contents),因此我可以在操作完成时手动删除该文件。

+2

嗨,+1并感谢您的回复。你写的很有道理。要回答你的问题,不,我没有尝试'xhr.upload.onprogress',但我会试一试。同时,我能够通过额外的AJAX调用来实现进度条。我不喜欢,对于每个进度条,我都必须发出几个甚至数百个AJAX呼叫。因此,我研究COMET和AJAX Long Polling等主题,它们在服务器和客户端之间建立了永久连接,并且可以更精确地更新进度栏。我正在研究它,所以我会看看它是否适用。 – 2013-03-02 14:23:17

+3

我必须告诉你,我刚刚尝试过'xhr.upload.onprogress'而不是'xhr.onprogress',它使所有不同。 'xhr.upload.onprogress' **工作得很好**。虽然我不明白其中的区别,但我非常感谢你提供了这个伟大的建议,并且我将你的答案标记为我的问题的*可接受的答案*。再次感谢你! – 2013-03-02 14:36:25

+0

有趣的解决方案。 – 2017-04-25 05:10:11