`
爪哇岛岛主
  • 浏览: 38757 次
  • 性别: Icon_minigender_1
  • 来自: 杭州(也就是天堂)
社区版块
存档分类
最新评论

文件上传进度条-----servlet+js

 
阅读更多
闲的没事,突然想起读书的时候文件上传进度条没有实现,现在想想,那时候真是太聪明了。如今,就刚刚,蛋疼得我做了一个,正如我所想到的一样,同事们确实是一阵嘲笑,还有一个小伙子居然说:‘这种东西网上很多成熟的东西了,我们不应该拘泥于这种小技术、、、’;我晕倒了,哎,学校里没实现的东西,虽然现在看来信手拈来,但是,自己做的东西总比网上荡好,我们很多同事就是这样,网上荡。。。对此,我只能说无语。。。。



其实上传进度条很简单,最简单的就是我下面的了,当然复杂的也有,不过我没用过。我以前也是用flash的,
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>文件上传进度条实例</title>
<link style="text/css" rel="stylesheet" href="css/index.css">
<script type="text/javascript" src="script/jquery-1.3.2.min.js"></script>
<script type="text/javascript" src="script/upload.js"></script>
</head>
<body>

	<fieldset>
		<legend>文件上传实例</legend>
		<form id="form" action="file.upload" method="post" enctype="multipart/form-data" target="frm">
			请选择上传的文件:<input type="file" name="uploadFile" />
		</form>
		<button id="btn">上传</button>
	</fieldset>
	
	<fieldset>
		<legend>进度显示</legend>
		<div id="process"><div id="data"></div></div>
	</fieldset>
	<iframe id="frm" name="frm" style="display:none;"></iframe>
</body>
</html>


package servlet;

import java.io.File;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.util.Iterator;
import java.util.List;

import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import javax.servlet.http.HttpSession;

import org.apache.commons.fileupload.DefaultFileItemFactory;
import org.apache.commons.fileupload.FileItem;
import org.apache.commons.fileupload.servlet.ServletFileUpload;



@SuppressWarnings("deprecation")
public class UpLoad extends HttpServlet {
	private static final long serialVersionUID = 1L;
 
	@SuppressWarnings("rawtypes")
	protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
		DefaultFileItemFactory factory = new DefaultFileItemFactory();
		HttpSession session = request.getSession();
		ServletFileUpload upload = new ServletFileUpload(factory);
		try{
			List tempList = upload.parseRequest(request);
			Iterator it = tempList.iterator();
			while(it.hasNext()){
				FileItem item = (FileItem)it.next();
				if(item.isFormField()){
					/**处理常规文本域**/
				}else{
					if(item.getName()!=null&&!item.getName().equals("")){
						Long size = item.getSize();
						System.out.println(size);
						File tempFile = new File("F:/"+item.getName());
						byte[] b = new byte[100];
						
						InputStream in = item.getInputStream();
						OutputStream out =new FileOutputStream(tempFile);
						int len = 0;
						int current = 0;
						session.setAttribute("total", size);
						while((len=in.read(b))>0){
							current += len;
							
							Thread.sleep(10);//故意延迟,以便看出效果
							session.setAttribute("current", current);
							out.write(b,0,len);
						}
					}
				}
			}
		}catch(Exception e){
			e.printStackTrace();
		}
	}

}



var total = 0;//文件总大小
var current = 0;//当前大小
var present= 0;//百分比
var timer = null;//定时触发事件
(function($){
	$(function(){
		$('#btn').click(function(){
		    timer = window.setInterval('getData()', 500);
		    $('#btn').attr('disabled','disabled');
			$('#form').submit();
		});
	});
})(jQuery);
var getData = function(){
	$.ajax({
		url:'file.data',
		success:function(msg){
			msg = eval('(' + msg + ')');
			total = msg.total;
			current = msg.current;
			if(present==100){
				$('#btn').attr('disabled','');
				window.clearInterval(timer);
			}
			present= (current/total)*100;
			$('#data').attr('innerHTML',present.toFixed(2)+'%');
		}
	});
};

  • 大小: 18.1 KB
分享到:
评论

相关推荐

    用servlet写的文件上传及下载功能带进度条

    自己用servlet写的文件上传及下载功能带进度条 主要用到两个jar:commons-fileupload-1.2.2.jar和commons-io-2.0.1.jar 内容介绍: com.fm.FileManagerService:一个servlet用来实现主要的文件上传下载逻辑的 ...

    ajax版自定义上传文件数量+进度条+JAVA+Servlet

    本文将深入讲解如何使用AJAX、JavaScript、Java和Servlet来实现一个自定义的文件上传功能,包括限制上传文件的数量以及展示进度条。 首先,我们需要在前端页面上创建一个表单,用户可以通过这个表单选择要上传的...

    JSP+servlet上传文件有 进度条

    总结来说,实现"JSP+servlet上传文件有进度条"需要结合JSP、Servlet、文件上传库(如Commons-FileUpload)以及前端的AJAX和JavaScript技术。通过异步请求和实时的进度反馈,为用户提供流畅的文件上传体验。在实际...

    servlet+jquery实现文件上次进度条

    "servlet+jquery实现文件上传进度条"这个主题正是为了改善这一情况,通过结合Java的Servlet技术和JavaScript的jQuery库,为用户提供了可视化的文件上传进度指示。 Servlet是Java服务器端编程的基础,它在Web应用中...

    Servlet上传文件并显示进度条

    9. **响应返回**:文件上传成功后,Servlet应返回一个表示成功的响应,以便前端更新界面状态,比如显示上传成功信息或重置进度条。 10. **测试与调试**:使用不同大小的文件进行测试,确保进度条准确无误地反映出...

    servlet多文件上传(带进度条)

    总的来说,实现Servlet多文件上传(带进度条)涉及的技术包括:Servlet的Part接口、文件流操作、Ajax异步请求、前端的进度条更新以及文件上传的错误处理和安全性措施。通过这些技术的结合,我们可以创建出一个高效且...

    基于servlet的简易文件上传(带进度条)

    在本文中,我们将深入探讨如何使用Java的Servlet技术来实现一个简易的文件上传功能,并且在上传过程中添加进度条的显示。Servlet是Java Web开发中不可或缺的一部分,它提供了服务器端处理HTTP请求的能力,使得我们...

    JSP文件上传进度条

    因此,引入“JSP文件上传进度条”技术可以显著改善这种情况,为用户提供实时的上传进度,增强交互体验。这个技术主要涉及到前端与后端的协同工作,下面我们将详细探讨这一主题。 首先,我们需要理解JSP(JavaServer...

    JSP文件上传 支持进度条显示.rar

    "JSP文件上传 支持进度条显示"这个项目是针对JSP环境设计的一个AJAX Web上传程序,它允许用户上传大文件(如单个文件100M),并具有文件上传进度条的可视化功能。以下将详细解析这个项目的知识点: 1. **JSP(Java...

    Extjs+java+swf多文件上传进度条显示项目

    标题中的“Extjs+java+swf多文件上传进度条显示项目”是一个综合性的Web开发实践,涉及到前端的用户界面、后端的数据处理以及文件上传过程中进度反馈的实现。这个项目利用了Extjs库来构建用户界面,Java作为服务器端...

    servlet 文件上传带进度条

    本项目"Servlet 文件上传带进度条"就是这样一个实例,它可以直接应用于你的工程,为用户提供实时的文件上传进度反馈。 首先,让我们了解文件上传的基本原理。传统的表单提交方式(POST)在上传文件时会刷新整个页面...

    ajax异步文件上传,servlet处理

    为了提供更好的用户体验,开发者通常会采用AJAX(Asynchronous JavaScript and XML)技术实现异步文件上传,避免传统方式下页面刷新带来的中断感。AJAX允许在后台与服务器进行通信,而无需刷新整个页面。本篇文章将...

    ext+servlet进度条(内附jar包)

    【标题】"ext+servlet进度条(内附jar包)"所涉及的知识点主要集中在Web开发领域,特别是关于前端EXT框架和后端Servlet的交互,以及如何实现文件上传过程中的实时进度条显示。EXT是一个强大的JavaScript库,用于构建富...

    JAVA -jquery 文件上传带进度条

    在Java和jQuery的世界里,实现文件上传带进度条的功能是一项常见的需求,特别是在用户交互体验日益重要的今天。这个功能可以提供给用户一个实时反馈,让他们了解文件上传的状态,从而提升用户体验。接下来,我们将...

    java+ajax上传文件带进度条

    在IT行业中,实现文件上传并显示进度条是常见的需求,特别是在Web应用中。这个主题“java+ajax上传文件带进度条”聚焦于使用Java后端和Ajax前端技术来完成这一功能。下面将详细介绍如何实现这一功能,以及涉及的关键...

    javaWEB上传+进度条代码包.7z

    1. **JavaWeb上传**: 在JavaWeb开发中,文件上传通常涉及到Servlet、Commons-FileUpload库或Spring框架的MultipartFile接口。Servlet API提供了`Part`接口处理HTTP请求中的多部分数据,而Commons-FileUpload则简化了...

    java实现带进度条的文件上传

    本示例“java实现带进度条的文件上传”提供了一个完整的解决方案,结合了HTML、Servlet以及swfupload库,来实现用户友好的文件上传体验,包括实时显示的进度条。 1. **HTML**:HTML是网页的基础,用于构建用户界面...

    使用jQuery ajaxFileUpload+servlet实现文件上传

    它的主要优点包括进度条显示、错误处理以及对多文件上传的支持。要使用这个插件,你需要在HTML页面中引入jQuery库和ajaxFileUpload.js文件,并设置一个用于选择文件的`&lt;input type="file"&gt;` 元素。 HTML示例: ```...

    apache 文件上传 进度条

    在Java Web开发中,文件上传是一项常见的功能,尤其是在用户需要提交大文件时,提供一个进度条界面能够显著提升用户体验。Apache Commons FileUpload库是Java中处理文件上传的标准库,它支持多部分表单数据的解析,...

Global site tag (gtag.js) - Google Analytics