[英]Bootstrap progress bar visible when downloading file from java servlet
[英]Showing a progress bar when downloading a file from the server
我需要向请求下载文件的用户显示进度条。 我正在使用J2EE应用程序生成该文件。 用户将提交表单数据以获取文件。 服务器将所有提交的数据进行操作,生成PDF文件并将其发送回客户端。
所以我想向用户显示进度条,直到文件到达客户端。 有没有办法做到这一点?
如果我理解你,你想要显示一个进度条,直到你的服务器准备发送文件,而不是显示下载文件的进度。
如果这是真的,那么你正在处理一个艰难的运动。 可靠的进度条需要知道(非常精确)您正在做什么以及需要多长时间。 在您的情况下,有许多不可靠的因素(其中一个,也许是最大的因素是网络本身)。
因此,大多数开发人员使用某种“无尽”动画来显示“正在进行中的工作”。
更新
根据您的评论,显示“正在进行中的工作”动画的最简单方法是
$.ajax({
url: "/myscripts/myserverscript",
type: "POST",
data: {
foo: "bar"
},
dataType: "text",
beforeSend: function(xhr){
// display a progress animation
},
complete: function(xhr, status){
// hide the animation
}
...
});
在单个请求的情况下。 您还可以为( .ajaxStart()
和.ajaxStop()
)设置全局ajax事件处理程序以设置show / hide功能。
服务器端文件生成的进度条:
我们假设服务器需要很多秒才能生成文件。 此事件由原始请求(阻塞操作)触发。 完成后,文件将被生成,并将被发送回客户端。
同时,您希望通过其他请求(ajax)调用服务器并获取当前为特定用户生成的文件的百分比。
这里的胶水部分是:
文件下载进度条:
最好把它留给浏览器的原生对话框。
在Java中,您只需在输入流周围包装一个javax.swing.ProgressMonitorInputStream,但请注意,除非服务器以分块流模式发送,否则显示实际上并不意味着什么,因为整个响应将在之前被读入内存。第一个字节传递给Java。
使用XMLHttpRequest,您可以下载文件并显示进度。
showProgressBar();
var xhr = new XMLHttpRequest();
xhr.open("GET", 'https://upload.wikimedia.org/wikipedia/commons/d/dd/Big_%26_Small_Pumkins.JPG', true);
xhr.responseType = "blob";
xhr.onprogress = function (e) {
console.log(e.loaded / e.total * 100);//shows downloaded percentage
setProgressBarPercentage(e.loaded / e.total * 100);
}
xhr.onload = function () {
hideProgressBar();
var urlCreator = window.URL || window.webkitURL;
var url = urlCreator.createObjectURL(this.response);
var link = document.createElement('a');
link.setAttribute('href', url);
link.setAttribute('download', 'FILENAME');
link.click();
}
xhr.send();
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.