• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    AJAX和JSP实现的基于WEB的文件上传的进度控制代码第1/2页
    1.引言
    2.实现代码
    2.1.服务器端代码
    2.1.1. 文件上传状态类(FileUploadStatus)
    2.1.2. 文件上传状态侦听类(FileUploadListener)
    2.1.3. 后台服务类(BackGroundService)
    2.1.4. 文件上传状态控制类(BeanControler)
    2.2. 客户端代码
    2.2.1. AjaxWrapper.js
    2.2.2. fileUpload.html
    2.2.3. result.jsp
    2.2.4. fileUpload.css
    2.3. 配置文件
    3. 结语

     1. 引言

       基于浏览器的文件上传,特别是对于通过input type="file">标签来实现上传的情况, 存在着严重的性能问题,因为用户提交了文件之后,在浏览器把文件上传到服务器的过程中,界面看上去似乎是静止的,如果是小文件还好些,如果不幸需要上传的是几兆、几十兆甚至上百兆的文件,我相信那是一种非常痛苦的体验,我们中间的很多人应该都有过此种不堪的经历。(一笑)

      现在我就针对这个问题给出一个解决方案,我们将实现一个具有监控能力的WEB上传的程序——它不仅把文件上传到服务器,而且"实时地"监视文件上传的实际过程。

    解决方案的基本思路是这样的:

    •   在Form提交上传文件同时,使用AJAX周期性地从Servlet轮询上传状态信息
    •   然后,根据此信息更新进度条和相关文字,及时反映文件传输状态
    •   如果用户取消上传操作,则进行相应的现场清理工作:删除已经上传的文件,在Form提交页面中显示相关信息
    •   如果上传完毕,显示已经上传的文件内容(或链接)

    在介绍源代码之前,我们先来看看程序运行界面:

     2. 实现代码

       实现代码想当然的有服务器端代码和客户端代码(呵呵),我们先从服务器端开始。

     2.1. 服务器端代码

      2.1.1. 文件上传状态类(FileUploadStatus)

       使用FileUploadStatus这个类记录文件上传状态,并将其作为服务器端与web客户端之间通信的媒介,通过对这个类对象提供上传状态作为服务器回应发送给web客户端, web客户端使用JavaScript获得文件上传状态。源代码如下:

    /**
     * 本例程演示了通过Web上传文件过程中的进度显示。您可以对本例程进行任何修改和使用。
     * 如果需要转载本例程,请您注明作者。
     *
     * 作者: 刘作晨
     * EMail:liuzuochen@gmail.com
     */
    package liuzuochen.sample.upload;
    import java.util.*;
    public class FileUploadStatus {
      //上传用户地址
      private String uploadAddr;
      //上传总量
      private long uploadTotalSize = 0;
      //读取上传总量
      private long readTotalSize = 0;
      //当前上传文件号
      private int currentUploadFileNum = 0;
      //成功读取上传文件数
      private int successUploadFileCount = 0;
      //状态
      private String status = "";
      //处理起始时间
      private long processStartTime = 0l;
      //处理终止时间
      private long processEndTime = 0l;
      //处理执行时间
      private long processRunningTime = 0l;
      //上传文件URL列表
      private List uploadFileUrlList = new ArrayList();
      //取消上传
      private boolean cancel = false;
      //上传base目录
      private String baseDir = "";
      public FileUploadStatus() {
      }
      public String getBaseDir() {
        return baseDir;
      }
      public void setBaseDir(String baseDir) {
        this.baseDir = baseDir;
      }
      public boolean getCancel() {
        return cancel;
      }
      public void setCancel(boolean cancel) {
        this.cancel = cancel;
      }
      public List getUploadFileUrlList() {
        return uploadFileUrlList;
      }
      public void setUploadFileUrlList(List uploadFileUrlList) {
        this.uploadFileUrlList = uploadFileUrlList;
      }
      public long getProcessRunningTime() {
        return processRunningTime;
      }
      public void setProcessRunningTime(long processRunningTime) {
        this.processRunningTime = processRunningTime;
      }
      public long getProcessEndTime() {
        return processEndTime;
      }
      public void setProcessEndTime(long processEndTime) {
        this.processEndTime = processEndTime;
      }
      public long getProcessStartTime() {
        return processStartTime;
      }
      public void setProcessStartTime(long processStartTime) {
        this.processStartTime = processStartTime;
      }
      public long getReadTotalSize() {
        return readTotalSize;
      }
      public void setReadTotalSize(long readTotalSize) {
        this.readTotalSize = readTotalSize;
      }
      public int getSuccessUploadFileCount() {
        return successUploadFileCount;
      }
      public void setSuccessUploadFileCount(int successUploadFileCount) {
        this.successUploadFileCount = successUploadFileCount;
      }
      public int getCurrentUploadFileNum() {
        return currentUploadFileNum;
      }
      public void setCurrentUploadFileNum(int currentUploadFileNum) {
        this.currentUploadFileNum = currentUploadFileNum;
      }
      public String getStatus() {
        return status;
      }
      public void setStatus(String status) {
        this.status = status;
      }
      public long getUploadTotalSize() {
        return uploadTotalSize;
      }
      public String getUploadAddr() {
        return uploadAddr;
      }
      public void setUploadTotalSize(long uploadTotalSize) {
        this.uploadTotalSize = uploadTotalSize;
      }
      public void setUploadAddr(String uploadAddr) {
        this.uploadAddr = uploadAddr;
      }
      public String toJSon() {
        StringBuffer strJSon = new StringBuffer();
        strJSon.append("{UploadTotalSize:").append(getUploadTotalSize()).append(
            ",")
            .append("ReadTotalSize:").append(getReadTotalSize()).append(",")
            .append("CurrentUploadFileNum:").append(getCurrentUploadFileNum()).
            append(",")
            .append("SuccessUploadFileCount:").append(
                getSuccessUploadFileCount()).append(",")
            .append("Status:'").append(getStatus()).append("',")
            .append("ProcessStartTime:").append(getProcessStartTime()).
            append(",")
            .append("ProcessEndTime:").append(getProcessEndTime()).append(
                ",")
            .append("ProcessRunningTime:").append(getProcessRunningTime()).
            append(",")
            .append("Cancel:").append(getCancel()).append("}");
        return strJSon.toString();
      }
    }
    

      2.1.2. 文件上传状态侦听类(FileUploadListener)

       使用Common-FileUpload 1.2版本(20070103)。此版本提供了能够监视文件上传情况的ProcessListener接口,使开发者通过FileUploadBase类对象的setProcessListener方法植入自己的Listener。 FileUploadListener类实现了ProcessListener,在整个文件上传过程中,它对上传进度进行监控,并且根据上传 情况实时的更新上传状态Bean。源代码如下:

    /**
     * 本例程演示了通过Web上传文件过程中的进度显示。您可以对本例程进行任何修改和使用。
     * 如果需要转载本例程,请您注明作者。
     *
     * 作者: 刘作晨
     * EMail:liuzuochen@gmail.com
     */
    package liuzuochen.sample.upload;
    import org.apache.commons.fileupload.ProgressListener;
    import javax.servlet.http.HttpServletRequest;
    public class FileUploadListener implements ProgressListener{
    	private HttpServletRequest request=null;
    	public FileUploadListener(HttpServletRequest request){
    		this.request=request;
    	}
    	/**
    	 * 更新状态
    	 */
    	public void update(long pBytesRead, long pContentLength, int pItems){
    		FileUploadStatus statusBean= BackGroundService.getStatusBean(request);
    		statusBean.setUploadTotalSize(pContentLength);
    		//读取完成
    	  if (pContentLength == -1) {
    	    statusBean.setStatus("完成对" + pItems +"个文件的读取:读取了 " + pBytesRead + " bytes.");
    	    statusBean.setReadTotalSize(pBytesRead);
    	    statusBean.setSuccessUploadFileCount(pItems);
    	    statusBean.setProcessEndTime(System.currentTimeMillis());
    	    statusBean.setProcessRunningTime(statusBean.getProcessEndTime());
    	  //读取中
    	  } else {
    	    statusBean.setStatus("当前正在处理第" + pItems +"个文件:已经读取了 " + pBytesRead + 
    "/" + pContentLength+ " bytes."); statusBean.setReadTotalSize(pBytesRead); statusBean.setCurrentUploadFileNum(pItems); statusBean.setProcessRunningTime(System.currentTimeMillis()); } BackGroundService.saveStatusBean(request,statusBean); } }
    12下一页阅读全文
    您可能感兴趣的文章:
    • Jsp页面实现文件上传下载类代码
    • jsp中点击图片弹出文件上传界面及预览功能的实现
    • jsp实现文件上传下载的程序示例
    • Jsp+Servlet实现文件上传下载 文件上传(一)
    • jsp文件上传与下载实例代码
    • jsp中点击图片弹出文件上传界面及实现预览实例详解
    • 利用jsp+Extjs实现动态显示文件上传进度
    • jsp 文件上传浏览,支持ie6,ie7,ie8
    • servlet+JSP+mysql实现文件上传的方法
    • JSP实现文件上传功能
    上一篇:DWR  util.js 学习笔记 整理
    下一篇:PPJOKE 0.1 (网页嵌入聊天)提供下载
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯

    《增值电信业务经营许可证》 苏B2-20120278

    AJAX和JSP实现的基于WEB的文件上传的进度控制代码第1/2页 AJAX,和,JSP,实现,的,基于,