<script></script>
实现文件上传的进度显示,我们先看看都有哪些问题我们要解决。
1 上传数据的处理进度跟踪
2 进度数据在用户页面的显示
就这么2个问题,
第一个问题,主要是组件的选择
必须支持数据处理侦听或通知的组件。当然,我肯定只用我自己的组件啦。基本原理是
1 使用request.getContentLength() 读取到处理数据的总长度,注意这个长度不等于文件的长度,因为Base64等编码会增加数据量,如果超过了允许的长度,直接返回-1;
2 在每读取一部分数据时(比如一行,或者64K,或者你自定义的字节数),将读取的字节数通知我们的进度跟踪程序。我取名为 UploadListener代码如下
/** *//**
* 处理附件上传的通知。
* 各位可以继承这个类,来实现自己的特殊处理。
*
* @author 赵学庆 www.java2000.net
*/
public class UploadListener ...{
// 调试模式将在控制台打印出一些数据
private boolean debug;
// 总数据字节数
private int total;
// 当前已经处理的数据字节数
private int totalCurrent = 0;
// 延迟,用来调试用,免得速度太快,根本卡看不到进度
private int delay = 0;
/** *//**
* 处理数据通知的方法。
* 保存已经处理的数据。并且在一定的比例进行延迟。默认每1%
* 如果不需用延迟,可以删掉内部的代码,加快速度。
*
* @param size 增加的字节数
*/
public void increaseTotalCurrent(long size) ...{
this.totalCurrent += size;
try ...{
currentRate = totalCurrent * 100 / total;
if (currentRate > lastRate) ...{
if (delay > 0) ...{
Thread.sleep(delay);
}
if (debug) ...{
System.out.println("rate=" + totalCurrent + "/" + total + "/" + (totalCurrent * 100 / total));
}
lastRate = currentRate;
}
} catch (Exception e) ...{
e.printStackTrace();
}
}
/** *//**
* 读取全部自己数
*
* @return
*/
public int getTotal() ...{
return total;
}
/** *//**
* 读取已经处理的字节数
*
* @return
*/
public int getTotalCurrent() ...{
return totalCurrent;
}
private long lastRate = 0;
private long currentRate = 0;
public int getDelay() ...{
return delay;
}
public void setDelay(int delay) ...{
this.delay = delay;
}
public void setTotal(int total) ...{
this.total = total;
}
public boolean isDebug() ...{
return debug;
}
public void setDebug(boolean debug) ...{
this.debug = debug;
}
}
3 下面我们来看上传的处理部分
Upload upload = new Upload(request);
// 增加了侦听进度的代码
UploadListener uploadListener = new UploadListener();
// 这句话我们后面再讨论,这个可是关键
session.setAttribute("uploadListener",uploadListener);
uploadListener.setDelay(0);
uploadListener.setDebug(true);
upload.setUploadListener(uploadListener);
upload.parse();
// 这句话同样重要,我们后面再讨论
session.setAttribute("uploadListener",null);
4 我们再看上传的表单部分
<script type="text/javascript">
function checkForm()...{
$("SHOW_FRAME").src="link.jsp";
$('SUBMIT').disabled=true;
Ext.MessageBox.show(...{
title: 'Please wait...',
msg: 'Initializing...',
width:240,
progress:true,
closable:false
});
$("MAIN_FORM").submit();
return false;
}
function setUploadProcess(total,current)...{
var rate = Number(current)/Number(total);
Ext.MessageBox.updateProgress(rate,'Uploading...'+current+"/"+total);
if(Number(current)>=Number(total))...{
closeUploadProcess();
}
}
function closeUploadProcess()...{
Ext.MessageBox.hide();
}
</script>
<iframe name="ACTION_FRAME" id="ACTION_FRAME" width="0" height="0"></iframe>
<iframe name="SHOW_FRAME" id="SHOW_FRAME" width="0" height="0"></iframe>
<form method="OST" id="MAIN_FORM" onsubmit="return checkForm()" enctype="multipart/form-data"
action="uploadFileSave.jsp" target="ACTION_FRAME">
<input type="file" size="50" name="file">
<input type="submit" ID="SUBMIT" value="Upload It">
</form>
第一个iframe用于提交表单数据,第二个就是我们用来获取处理数据进度信息的。
提交表单很简单,target指向了我们的第一个iframe
我们看一下JS
checkForm 里面第一句就是关键的读取进度信息的页面,我们在第二个iframe里面获得。然后就是弹出进度的显示框,我使用了Ext. 然后提交上传表单
setUploadProcess 用来更新进度框上面的数据,第一个参数是数据总共的大小,第二个参数是已经处理的大小。
closeUploadProcess 关闭进度框
5 最后,我们来看读取进度信息的页面
<%@ page language="java" contentType="text/html; charset=utf-8" pageEncoding="utf-8"%>
<%@include file="../package.inc.jsp"%>
<%
response.setHeader("ragma", "no-cache");
response.setHeader("Cache-Control", "no-cache");
response.setDateHeader("Expires", 0);
response.setBufferSize(0);
UploadListener uploadListener = null;
分享到:
相关推荐
Java动态显示文件上传进度的实现涉及到了Web开发中的文件上传功能与用户界面的实时交互。在Java中,要实现这一功能,我们需要解决两个主要问题:一是跟踪上传数据的处理进度,二是将进度数据在用户界面上正确显示。...
这个名为“带进度条的文件上传下载组件(JAVA)”的项目,显然聚焦于提供一个用户友好的交互体验,通过显示进度条来增强用户体验,使用户能够清晰地看到文件上传或下载的进度。下面我们将深入探讨这一组件涉及的主要...
标题中的“Extjs+java+swf多文件上传进度条显示项目”是一个综合性的Web开发实践,涉及到前端的用户界面、后端的数据处理以及文件上传过程中进度反馈的实现。这个项目利用了Extjs库来构建用户界面,Java作为服务器端...
在Java Web开发中,实现一个模拟数据导入或文件上传进度条功能可以极大提升用户体验,让用户在等待过程中心中有数。这个功能通常涉及到前端与后端的交互,涉及到的技术包括Servlet、JSP、jQuery和Ajax。下面我们将...
AJAX(Asynchronous JavaScript and XML)允许我们在不刷新整个页面的情况下与服务器进行异步通信,非常适合用来传递文件上传进度。 在前端,我们可以创建一个表单,使用HTML5的`<input type="file" multiple>`来...
实现Java大文件上传通常需要以下几个关键步骤: 1. **前端界面**:首先,我们需要一个用户友好的界面,包含文件选择器和进度条。用户选择文件后,利用HTML5的File API获取文件信息,并通过AJAX请求发送到服务器。DW...
8. **文件上传进度显示**: 可能还涉及到文件上传进度的实时反馈,这可以通过监听AJAX事件或者使用HTML5的File API来实现。 9. **安全考虑**: 文件上传过程中,必须考虑到安全性问题,如防止恶意文件上传、大小限制...
在Web开发中,文件上传是一项常见的...总结,AJAX+JSP实现的文件上传进度控制技术,通过异步通信和动态更新,提高了用户的交互体验。在实际开发中,我们需要考虑安全性、性能和用户体验,合理设计和优化文件上传功能。
它支持分块上传、断点续传和进度显示等功能,使得在Web应用中实现文件上传和下载更加稳定和高效。 3. **JSP文件**: - `uploadXml.jsp`:这个页面展示了文件上传的对话框。它可能包含了HTML表单元素,如`...
要实现文件上传进度的显示,我们需要以下步骤: 1. **配置Servlet**:在web.xml中配置一个专门处理文件上传的Servlet,设置multipart/form-data为编码类型,以便处理文件上传请求。 ```xml <servlet-name>...
JSP(JavaServer Pages)则用于创建动态网页,通常用来展示上传进度或结果。 2. **Multipart解析**:Java EE中,通常使用Apache Commons FileUpload库来处理多部分(multipart/form-data)的HTTP请求,这是上传文件...
在Java编程领域,文件上传和下载是常见的功能...通过阅读和运行这个TestUp文件,你可以更好地掌握Java文件上传下载的具体实现。实践中,你可能需要结合实际项目需求调整这些代码,例如添加权限控制、进度显示等功能。
- 提供进度条显示文件上传进度,提升用户体验。这可能需要JavaScript库如jQuery或Ajax技术来实现异步通信。 9. **错误处理**: - 编程中应处理各种异常情况,如文件类型不匹配、存储空间不足、网络中断等,并向...
在实际项目中,还需要考虑错误处理、安全性(防止文件覆盖、非法文件上传等)、用户体验优化(如上传进度显示)等问题。`SmartUpload`库提供的API可以方便地解决这些问题,使得文件上传下载功能的实现更加高效和稳定...
本项目以“jsp版 上传文件并且显示上传进度条”为主题,旨在实现一个功能完善的文件上传系统,该系统不仅能够处理文件上传,而且能够实时反馈上传进度,为用户提供更好的交互体验。 首先,我们来看`jsp`(Java...
这个"java大文件上传"的项目很可能提供了一个实现大文件分块上传的示例,帮助开发者处理超过服务器默认限制的大文件。让我们深入探讨一下Java中大文件上传的相关知识点。 1. **Servlet 3.0及以上版本的支持**: ...
总的来说,通过Java和Ajax的结合,我们可以构建出一个高效、用户体验良好的文件上传系统,不仅能够异步上传文件,还能实时显示上传进度和速度,大大提升了用户的操作体验。在实际开发中,还需要考虑文件大小限制、...
通过解压并运行这些文件,你可以看到一个实际工作的文件上传进度显示系统。记得在你的应用环境中配置好Servlet容器,如Tomcat,并将这些文件部署上去。 总的来说,通过结合JSP、Servlet和AJAX技术,我们可以构建出...
在文件上传过程中,实时显示进度条、上传速度、已上传大小、剩余大小、已用时间以及预计剩余时间,这需要后端提供进度信息。服务器可以在处理文件部分时记录已处理的数据量,然后通过Ajax回调将这些信息传递给前端。...
本项目聚焦于实现一个Java Web应用,该应用具备多文件上传、进度条展示、预览以及删除等功能,这对于提升用户体验至关重要。接下来,我们将详细讨论这些知识点。 首先,我们来看“java jsp upload”。Java Server ...