我发现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的
预先感谢您。
你见过这个吗? http://stackoverflow.com/questions/49564/how-to-implement-file-upload-progress-bar-on-web – 2013-03-02 12:54:16
@JohnZwinck:嗨。感谢您的评论。我的问题可能非常具体?您的链接显示了进度条的各种实现,但它们中没有一个与HTTP PUT请求相关。为HTTP POST请求创建进度条相当简单,但问题是**相同的代码不适用于HTTP PUT请求**。 – 2013-03-02 13:00:20
你为什么不回避POST? – 2013-03-02 13:57:16