日期:2014-05-17  浏览次数:20756 次

java+HTML5的XMLHttpRequest Level 2新特性实现文件上传,上传进度条

java+JS+XMLHttpRequest Level 2 实现文件上传, 有进度条

第一次发帖,亲喷。 需求: 1.实现上传进度。 2.实现上传进度条。 3.上传到HDFS分布式存储系统。 4.后台java实现。 准备做一个进度条上传文件到分布式存储系统,对于刚做前台的我感觉有点难度。 难点: 上传进度条感觉有点困难,本来想在后台双线程实现,把进度值传到session里面,前台获取session值实现。后来发现前台不能直接获取session值,然后就思考利用web服务器不断发送请求模拟双线程,检查上传文件大小的方法实现进度。实现以后发现进度很不科学,进度刚开始动一下,然后直接跳到100%,可能是应该HDFS要均衡负载的原因。后台就想直接前台实现上传进度吧。查了一些资料发现以前都是用flash实现进度。然而我又没有接触过,后来看到一篇大神阮一峰的文[url]http://www.ruanyifeng.com/blog/2012/09/xmlhttprequest_level_2.html[/url],发现js可以直接实现进度条,后来又在网上搜索了一些资料,有人已经写了一个包装的不错的js脚本文章地址[url]http://blog.csdn.net/never_say_goodbye/article/details/8598521[/url],好吧那就干起来呗。遗憾的是后台php接受的,我需要的是java的后台,想想应该简单吧,于是又去搜索了一个,这一篇IBM的帖子解决了我的问题[url]http://www.ibm.com/developerworks/cn/web/1101_hanbf_fileupload/[/url],我的样式都是沿用了上面的样式。感觉还是不错的。

上 J8:



?Controller层的代码:

	@RequestMapping(value = "/uploadFile", method = RequestMethod.POST)
	@ResponseBody
	public ResultJson upLoad(String fileID, HttpServletRequest request,HttpServletResponse response) throws IOException,InterruptedException, FileUploadException {
		request.setCharacterEncoding("utf-8");
		// String fileName = request.getParameter("fileName");
		String fileName = request.getHeader("fileName");
		String fname = null;
		System.out.println(request.getHeader("User-Agent"));
		/**处理中文乱码*/
		if (request.getHeader("User-Agent").toLowerCase().indexOf("firefox") > 0) {
			fname = new String(fileName.getBytes("ISO8859-1"), "UTF-8"); // firefox浏览器
		} else if (request.getHeader("User-Agent").toUpperCase().indexOf("MSIE") > 0) {
			fname = URLEncoder.encode(fileName, "UTF-8");// IE浏览器
		} else if (request.getHeader("User-Agent").toUpperCase().indexOf("CHROME") > 0) {
			fname = new String(fileName.getBytes("iso-8859-1"), "utf-8");// 谷歌
		}
		
		String path = fileID;
		boolean success = false;
		System.out.println(fname);
		ServletInputStream inputStream = request.getInputStream();
		success = servHdfs.upLoadHDFSFile(path, inputStream, fname);
		if (success) {
			return ResultJson.trueState("Success");
		}
		return ResultJson.falseState("error");
	}

?js代码(需要导入封装好的 jquery.html5uploader.js):

	$('#upload').html5uploader({
			auto : false,
			multi : true,
			removeTimeout : 9999999,
			url : 'uploadFile.do?fileID=' + NBC.Tree.node.id,
			// 正在上传
			onUploadStart : function() {

			},
			// 初始化
			onInit : function() {

			},
			// 上传成功
			onUploadComplete : function() {
				$('#hdfsDatagrid').datagrid('load', []);
				$.messager.show({
					title : '提示',
					msg : '文件上传成功!',
				});
			}

		});

?html代码:

<div id="upload"></div>

貌似很简单的样子,但是其中遇到的一系列问题还是挺多的?

借花献佛上传代码

?