`
liss
  • 浏览: 825333 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类
最新评论

AJAX+JSP实现基于WEB的文件上传的进度控制(2)

    博客分类:
  • Ajax
阅读更多

2.1.3. 后台服务类(BackGroundService)

   BackGroundService这个Servlet类负责接收Form Post数据、回应状态轮询请求、处理取消文件上传的请求。 尽管可以把这些功能相互分离开来,但为了简单明了,还是将它们放到Servlet中,只是由不同的方法进行分割。 源代码如下:

/**
 * 本例程演示了通过Web上传文件过程中的进度显示。您可以对本例程进行任何修改和使用。
 * 如果需要转载本例程,请您注明作者。
 *
 * 作者: 刘作晨
 * EMail:liuzuochen@gmail.com
 */
package liuzuochen.sample.upload;


/**
 * Title: 后台服务
 * * Description: 为客户端提供上传及文件传输状态查询服务
 *
 */
import java.io.File;
import java.io.IOException;
import java.util.List;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.apache.commons.fileupload.FileItem;
import org.apache.commons.fileupload.FileUploadException;
import org.apache.commons.fileupload.disk.DiskFileItemFactory;
import org.apache.commons.fileupload.servlet.*;
public class BackGroundService extends javax.servlet.http.HttpServlet implements
         javax.servlet.Servlet {
     public static final String UPLOAD_DIR = "/upload";
     public static final String DEFAULT_UPLOAD_FAILURE_URL = "./result.jsp";
     public BackGroundService() {
         super();
     }
     protected void doGet(HttpServletRequest request,
                          HttpServletResponse response) throws ServletException,
             IOException {
         doPost(request, response);
     }
     /**
      * 从文件路径中取出文件名
      */
     private String takeOutFileName(String filePath) {
         int pos = filePath.lastIndexOf(File.separator);
         if (pos > 0) {
             return filePath.substring(pos + 1);
         } else {
             return filePath;
         }
     }
     /**
      * 从request中取出FileUploadStatus Bean
      */
     public static FileUploadStatus getStatusBean(
             HttpServletRequest request) {
         BeanControler beanCtrl = BeanControler.getInstance();
         return beanCtrl.getUploadStatus(request.getRemoteAddr());
     }
     /**
      * 把FileUploadStatus Bean保存到类控制器BeanControler
      */
     public static void saveStatusBean(
             HttpServletRequest request,
             FileUploadStatus statusBean) {
         statusBean.setUploadAddr(request.getRemoteAddr());
         BeanControler beanCtrl = BeanControler.getInstance();
         beanCtrl.setUploadStatus(statusBean);
     }
     /**
      * 删除已经上传的文件
      */
     private void deleteUploadedFile(HttpServletRequest request) {
         FileUploadStatus satusBean = getStatusBean(request);
         for (int i = 0; i < satusBean.getUploadFileUrlList().size(); i++) {
             File uploadedFile = new File(request.getRealPath(UPLOAD_DIR) +
                                          File.separator +
                                          satusBean.getUploadFileUrlList().
                                          get(i));
             uploadedFile.delete();
         }
         satusBean.getUploadFileUrlList().clear();
         satusBean.setStatus("删除已上传的文件");
         saveStatusBean(request, satusBean);
     }
     /**
      * 上传过程中出错处理
      */
     private void uploadExceptionHandle(
             HttpServletRequest request,
             String errMsg) throws ServletException, IOException {
         //首先删除已经上传的文件
         deleteUploadedFile(request);
         FileUploadStatus satusBean = getStatusBean(request);
         satusBean.setStatus(errMsg);
         saveStatusBean(request, satusBean);
     }
     /**
      * 初始化文件上传状态Bean
      */
     private FileUploadStatus initStatusBean(HttpServletRequest
             request) {
         FileUploadStatus satusBean = new FileUploadStatus();
         satusBean.setStatus("正在准备处理");
         satusBean.setUploadTotalSize(request.getContentLength());
         satusBean.setProcessStartTime(System.currentTimeMillis());
         satusBean.setBaseDir(request.getContextPath() + UPLOAD_DIR);
         return satusBean;
     }
     /**
      * 处理文件上传
      */
     private void processFileUpload(HttpServletRequest request,
                                    HttpServletResponse response) throws
             ServletException, IOException {
         DiskFileItemFactory factory = new DiskFileItemFactory();
         //设置内存缓冲区,超过后写入临时文件
         factory.setSizeThreshold(10240000);
         //设置临时文件存储位置
         factory.setRepository(new File(request.getRealPath("/upload/temp")));
         ServletFileUpload upload = new ServletFileUpload(factory);
         //设置单个文件的最大上传值
         upload.setFileSizeMax(102400000);
         //设置整个request的最大值
         upload.setSizeMax(102400000);
         upload.setProgressListener(new FileUploadListener(request));
         //保存初始化后的FileUploadStatus Bean
         saveStatusBean(request, initStatusBean(request));
         String forwardURL = "";
         try {
             List items = upload.parseRequest(request);
             //获得返回url
             for (int i = 0; i < items.size(); i++) {
                 FileItem item = (FileItem) items.get(i);
                 if (item.isFormField()) {
                     forwardURL = item.getString();
                     break;
                 }
             }
             //处理文件上传
             for (int i = 0; i < items.size(); i++) {
                 FileItem item = (FileItem) items.get(i);
                 //取消上传
                 if (getStatusBean(request).getCancel()) {
                     deleteUploadedFile(request);
                     break;
                 }
                 //保存文件
                 else if (!item.isFormField() && item.getName().length() > 0) {
                     String fileName = takeOutFileName(item.getName());
                     File uploadedFile = new File(request.getRealPath(UPLOAD_DIR) +
                                                  File.separator + fileName);
                     item.write(uploadedFile);
                     //更新上传文件列表
                     FileUploadStatus satusBean =
                             getStatusBean(request);
                     satusBean.getUploadFileUrlList().add(fileName);
                     saveStatusBean(request, satusBean);
                     Thread.sleep(500);
                 }
             }
         } catch (FileUploadException e) {
             uploadExceptionHandle(request, "上传文件时发生错误:" + e.getMessage());
         } catch (Exception e) {
             uploadExceptionHandle(request, "保存上传文件时发生错误:" + e.getMessage());
         }
         if (forwardURL.length() == 0) {
             forwardURL = DEFAULT_UPLOAD_FAILURE_URL;
         }
         request.getRequestDispatcher(forwardURL).forward(request, response);
     }
     /**
      * 回应上传状态查询
      */
     private void responseStatusQuery(HttpServletRequest request,
                                               HttpServletResponse response) throws
             IOException {
         response.setContentType("text/xml");
         response.setHeader("Cache-Control", "no-cache");
         FileUploadStatus satusBean = getStatusBean(request);
         response.getWriter().write(satusBean.toJSon());
     }
     /**
      * 处理取消文件上传
      */
     private void processCancelFileUpload(HttpServletRequest request,
                                          HttpServletResponse response) throws
             IOException {
         FileUploadStatus satusBean = getStatusBean(request);
         satusBean.setCancel(true);
         saveStatusBean(request, satusBean);
         responseStatusQuery(request, response);
     }
     protected void doPost(HttpServletRequest request,
                           HttpServletResponse response) throws ServletException,
             IOException {
         boolean isMultipart = ServletFileUpload.isMultipartContent(request);
         if (isMultipart) {
             processFileUpload(request, response);
         } else {
             request.setCharacterEncoding("UTF-8");
             if (request.getParameter("uploadStatus") != null) {
                 responseStatusQuery(request, response);
             }
             if (request.getParameter("cancelUpload") != null) {
                 processCancelFileUpload(request, response);
             }
         }
     }
}

   2.1.4. 文件上传状态控制类(BeanControler)

   这是一个单例类,它的功能是为客户端保存文件上传状态,这里我没有使用Session来存储文件上传状态,因为对于AJAX这种异步调用,服务器会开启不 同的Session,所以无法通过Session保存文件上传状态。 我并不认为这种方法最好,如果有更好的方法,欢迎大家一起讨论。 源代码如下:

/**
 * 本例程演示了通过Web上传文件过程中的进度显示。您可以对本例程进行任何修改和使用。
 * 如果需要转载本例程,请您注明作者。
 *
 * 作者: 刘作晨
 * EMail:liuzuochen@gmail.com
 */

package liuzuochen.sample.upload;
/**
 * Title: 类控制器
 *
 * Description: 主要作用是对FileUploadStatus进行管理,为客户端提供相应的
 * FileUploadStatus类对象。这是一个单例类。
 *
 */
import java.util.Vector;
public class BeanControler {
     private static BeanControler beanControler = new BeanControler();
     private Vector vector = new Vector();
     private BeanControler() {
     }
     public static BeanControler getInstance() {
         return beanControler;
     }
     /**
      * 取得相应FileUploadStatus类对象的存储位置
      */
     private int indexOf(String strID) {
         int nReturn = -1;
         for (int i = 0; i < vector.size(); i++) {
             FileUploadStatus status = (FileUploadStatus) vector.elementAt(i);
             if (status.getUploadAddr().equals(strID)) {
                 nReturn = i;
                 break;
             }
         }
         return nReturn;
     }
     /**
      * 取得相应FileUploadStatus类对象
      */
     public FileUploadStatus getUploadStatus(String strID) {
         return (FileUploadStatus) vector.elementAt(indexOf(strID));
     }
     /**
      * 存储FileUploadStatus类对象
      */
     public void setUploadStatus(FileUploadStatus status) {
         int nIndex = indexOf(status.getUploadAddr());
         if ( -1 == nIndex) {
             vector.add(status);
         } else {
             vector.insertElementAt(status, nIndex);
             vector.removeElementAt(nIndex + 1);
         }
     }
     /**
      * 删除FileUploadStatus类对象
      */
     public void removeUploadStatus(String strID){
         int nIndex = indexOf(strID);
         if(-1!=nIndex)
             vector.removeElementAt(nIndex);
     }
}

2.2. 客户端代码

   客户端我们采用Prototype框架。请下载。

   2.2.1. AjaxWrapper.js

   AjaxWrapper.js对Prototype进行了封装。请下载分析

   2.2.2. fileUpload.html

   fileUpload.html是文件上传界面。 请下载。

   2.2.3. result.jsp

   result.jsp是文件上传结果显示界面。 请下载

   2.2.4. fileUpload.css

   fileUpload.css是样式文件。 源代码如下:

body {
color:#000;
background-color:white;
font:15px Georgia, "Lucida Grande", Arial, sans-serif;
letter-spacing:0.01em;
margin:15px;
}
#controlPanel,#resultPanel{
width:700px;
margin:20px auto;
padding:25px;
border:3px solid gray;
-moz-border-radius:10px;
background:#f8f8f8;
}
#errorArea{
width:400px;
margin:20px auto;
padding:25px;
border:3px solid gray;
-moz-border-radius:10px;
background:red;
}
#normalMessageArea{
width:400px;
margin:20px auto;
padding:25px;
border:3px solid gray;
-moz-border-radius:10px;
background:yellow;
}
#progressBar { padding-top: 5px; }
#totalProgressBarBox {
width: 350px;
height: 20px;
border: 1px inset;
background: #eee;
}
#totalProgressBarBoxContent {
width: 0;
height: 20px;
border-right: 1px solid #444;
background: #9ACB34;
}

2.3. 配置文件

   web.xml中完成Servlet的配置。

<?xml version="1.0" encoding="UTF-8"?>
<web-app id="WebApp_ID" version="2.4" xmlns="http://java.sun.com/xml/ns/j2ee" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd">
<display-name>AjaxPractice</display-name>
<servlet>
<description></description>
<display-name>BackGroundService</display-name>
<servlet-name>BackGroundService</servlet-name>
<servlet-class>liuzuochen.sample.upload.BackGroundService</servlet-class>
</servlet>

<servlet-mapping>
<servlet-name>BackGroundService</servlet-name>
<url-pattern>*.action</url-pattern>
</servlet-mapping>
<welcome-file-list>
<welcome-file>index.html</welcome-file>
<welcome-file>index.htm</welcome-file>
<welcome-file>index.jsp</welcome-file>
<welcome-file>default.html</welcome-file>
<welcome-file>default.htm</welcome-file>
<welcome-file>default.jsp</welcome-file>
</welcome-file-list>
</web-app>

3. 结语

   整个程序到这里就介绍完了,希望它多少能为您的工作或学习带来点儿帮助。

分享到:
评论
1 楼 mogui258 2010-08-22  
没看见源码啊?
怎么下载?

相关推荐

    AJAX+JSP实现基于WEB的文件上传的进度控制

    AJAX+JSP实现基于WEB的文件上传的进度控制

    AJAX+JSP实现基于WEB的文件上传的进度控制.rar

    AJAX+JSP实现基于WEB的文件上传的进度控制.rar。。。。。。。。。。

    jsp中使用ajax实现web进度条

    jsp中使用ajax实现web进度条

    AJAX实现基于WEB的文件上传的进度控制

    文件上传状态控制类(BeanControler)2.2.客户端代码2.2.1.AjaxWrapper.js2.2.2.fileUpload.html2.2.3.result.jsp2.2.4.fileUpload.css2.3.配置文件3.结语1.引言 基于浏览器的文件上传,特别是对于通过标

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

    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. 结语 BODY { MARG

    纯JSP带进度条无刷新的多文件上传

    (2)可上传任意类型、不限大小的文件; (3)支持中文文件名; (4)巧妙实现页面无刷新处理; (5)上传进度提示; (6)采用专用线程负责上传; (7)支持多文件上传; (8)具体效果请看...

    完整java上传附件案例,SSH2架构,开源

    标签用途和功能介绍 ... WEB-INF/jsp/upload/upload-ajax.jsp 封装选择上传文件的操作 文件 js/upload/upload.js 封装上传文件的脚本程序 其他文件 WEB-INF/tld/upload包下所有文件.tld文件(设置标签属性)

    JSP+Mootools实现的Ajax无刷新上传文件

    内容索引:JSP源码,上传下载,Mootools,JSP上传文件 JSP+Mootools实现的Ajax无刷新上传文件,附有完整的JAVA源文件,方便您的二次开发和修改,带上传进度条,适时显示上传进度,演示截图如上示,对于学习来说,这个...

    ajax jsp dhtmlxvault 動態上傳

    dhtmlxVault是一个在WEB页面上实现文件上传进度控制的JavaScript库 新版本实现了完全的本地化、包括按钮文本,另外提升了 PHP 对错误的处理,增加文件大小限制等。

    任务书-基于JAVA-WEB技术的旅行社网站系统设计.doc

    " "1、在全面分析旅游信息化系统技术实现手段,建立动态网站以及开发环境,同时将对 " "Web Services、JSP、JDBC 等数据源驱动程序以及服务环境 Tomcat建立等作相应的研究 " "。 " "2、研究关于建立动态旅游服务...

    AJAX基础概念、核心技术与典型案例(内涵动态实例)

    当上传文件时,客户端同时显示文件上传的进度,从而及时了解文件传送情况。 /test.html 上传文件 /periodcal.jsp 上传文件后台处理页面 / prototype.js prototype框架类库文件 第21章(/ch21)...

    源码基于JSP的javapms-1.2-beta.rar

    JavaPMS(Java Project Management System)是一款基于JSP(Java Server Pages)的项目管理软件,它采用MVC(Model-View-Controller)设计模式,具有高度的可扩展性和灵活性。该源码资料包javapms-1.2-beta.rar提供...

    房地产销售管理系统

    由当前流行的jsp+struts2+hibernate+spring+ajax等最新技术实现; 有很高的安全性,对系统中的任何操作均有日志记录;方便快捷,支持通过Excel文件批量导入导出各种数据,实现与第三方软件的无缝连接; 针对各种房...

    房地产销售管理系统V3.0

    由当前流行的jsp+struts2+hibernate+spring+ajax等最新技术实现; 有很高的安全性,对系统中的任何操作均有日志记录;方便快捷,支持通过Excel文件批量导入导出各种数据,实现与第三方软件的无缝连接; 针对各种房...

    java_jsp项目源码_+sql操作系统教学网站设计(论文+程序).rar

    本项目是一个基于Java JSP技术、结合MySQL数据库的在线教学网站设计与实现。该网站旨在为教育工作者和学习者提供一个互动式的教学平台,支持课程发布、在线学习、试题管理、在线测试及数据统计等功能。项目采用模块...

    简历信息管理系统.zip

    3、组长应(疫情期间可通过网络)组织组员进行题目的分析与系统总体设计、协调组内人员分工、控制开发进度和系统总体联调。 4、考核答辩以小组为单位进行,每组一个代表参加答辩,代表由教师从小组成员中随机挑选,...

    积分管理系统java源码-web:网络

    EasyUI开发前端页面,利用jQuery文件上传插件实现拖拽上传的效果并对文件类型、大小、数量进行控制;利用search-box实现查找功能 统一的异常处理 JSP JSTL JavaScript kindeditor富文本编辑器,处理图片上传和

Global site tag (gtag.js) - Google Analytics