后端springmvc,前端html5的FormData实现文件断点上传
前言
最近项目中有使用到文件断点上传,得空便总结总结,顺便记录一下,毕竟“好记性不如烂笔头”。
后端代码:
package com.test.controller; import java.io.BufferedOutputStream;
import java.io.File;
import java.io.FileOutputStream;
import java.util.UUID; import org.apache.commons.io.FileUtils;
import org.apache.commons.io.FilenameUtils;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestMethod;
import org.springframework.web.bind.annotation.RequestParam;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.multipart.MultipartFile; @Controller
public class UploadController { @ResponseBody // 返回rest json
@RequestMapping(value = {"/rest/saveUploadFileAsChunk"}, method = RequestMethod.POST, produces = "application/json")
public File saveUploadFileAsChunk(@RequestParam(required = false) MultipartFile file,
@RequestParam(required = true) Integer chunk, // 分割块数
@RequestParam(required = true) Integer chunks, // 总分割数
@RequestParam(required = true) String tempFileName //临时文件名 必须带后缀名
) throws Exception{
if(null != file){
// 保存临时文件
String chunkName = tempFileName;
if (chunk != null) {
chunkName = chunk + "_" + tempFileName;
}
File savedFile = new File("普通存放文件的路径", chunkName);
if (!savedFile.getParentFile().exists())
savedFile.getParentFile().mkdirs();
file.transferTo(savedFile); //将MultipartFile转存到file对象
} //如果到最后一个分割块,则做合并处理
if (chunk != null && chunk + 1 == chunks) {
String newFileName = UUID.randomUUID().toString().replace("-", "").concat(".").concat(FilenameUtils.getExtension(tempFileName));
BufferedOutputStream outputStream = new BufferedOutputStream(new FileOutputStream(new File("普通存放文件的路径", newFileName)));
// 遍历文件合并 chunks,循环将文件写入新的文件中,并且删除之前的临时文件
for (int i = 0; i < chunks; i++) {
File tempFile = new File("普通存放文件的路径", i + "_" + tempFileName);
byte[] bytes = FileUtils.readFileToByteArray(tempFile); //将file对象解析城byte数组
outputStream.write(bytes);
outputStream.flush();
tempFile.delete();
}
outputStream.flush();
outputStream.close();
File reallyFile = new File("普通存放文件的路径", newFileName); //reallyFile即最后合并的文件
return reallyFile;
}
return null;
}
}
前端代码:
var setsize = 10 * 1024; //1024字节 = 1KB * 10 即每次10k /** *参数filepath就是本地文件路径,主要就是用于放在localStorage中确定唯一性
file : js的Blob对象
*/
function uplaod(filepath,file){
var filesize = file.size;
var filecount = filesize/setsize; //计算出可以分成几块 var i = localStorage.getItem(filepath);
i = (i!=null && i!="")?parseInt(i):0; if(i < filecount){
//新建一个FormData对象
var formData = new FormData(); //++++++++++
var blobfile;
if((filesize - i * setsize) > setsize){
blobfile = file.slice(i*setsize,(i+1)*setsize);
}else{
//代表是最后一此了
blobfile = file.slice(i*setsize,filesize);
} formData.append('chunk', i); //++++++++++当前文件块
formData.append('chunks', Math.ceil(filecount)); //++++++++++ 总块数
formData.append("tempFileName",fileName); //临时文件名 带uuid的
formData.append('file', blobfile); if(i < filecount){
$.ajax({
url: PATROL_CONSTANTS.SRV_URL+"/rest/saveUploadFileAsChunk",
type: 'POST',
data: formData,
processData: false,
contentType: false,
success: function (responseStr) {
localStorage.setItem(filepath,i+1);
var rs = filecount <= 0 ? "0%" : (Math.round((i+1) / Math.ceil(filecount) * 10000) / 100.00 + "%");
console.log("进度百分比:"+rs); uploadFile(filepath,file); //递归调用
},
error: function (responseStr) {
console.log("上传失败,重复尝试!");
console.log(responseStr);
uploadFile(filepath,file);
}
});
}else{
//上传完成后,则将对应的localStorage移除掉
localStorage.removeItem(filepath);
}
}
转发请标注原文地址:http://www.cnblogs.com/dinglinjie/p/7458901.html
阿杰de博客,qq群:112465270
后端springmvc,前端html5的FormData实现文件断点上传的更多相关文章
- 文件断点上传,html5实现前端,java实现服务器
断点上传能够防止意外情况导致上传一半的文件下次上传时还要从头下载,网上有很多关于断点的实现,这篇文章只是从前到后完整的记录下一个可用的实例,由于生产环境要求不高,而且就是提供给一两个人用,所以我简化了 ...
- 前端利用webuploader实现超大文件分片上传、断点续传
本人在2010年时使用swfupload为核心进行文件的批量上传的解决方案.见文章:WEB版一次选择多个文件进行批量上传(swfupload)的解决方案. 本人在2013年时使用plupload为核心 ...
- java HTTP文件断点上传
之前仿造uploadify写了一个HTML5版的文件上传插件,没看过的朋友可以点此先看一下~得到了不少朋友的好评,我自己也用在了项目中,不论是用户头像上传,还是各种媒体文件的上传,以及各种个性的业务需 ...
- asp.net 如何实现大文件断点上传功能?
之前仿造uploadify写了一个HTML5版的文件上传插件,没看过的朋友可以点此先看一下~得到了不少朋友的好评,我自己也用在了项目中,不论是用户头像上传,还是各种媒体文件的上传,以及各种个性的业务需 ...
- jsp文件断点上传
之前仿造uploadify写了一个HTML5版的文件上传插件,没看过的朋友可以点此先看一下~得到了不少朋友的好评,我自己也用在了项目中,不论是用户头像上传,还是各种媒体文件的上传,以及各种个性的业务需 ...
- jsp+servlet怎么实现文件断点上传下载
我们平时经常做的是上传文件,上传文件夹与上传文件类似,但也有一些不同之处,这次做了上传文件夹就记录下以备后用. 这次项目的需求: 支持大文件的上传和续传,要求续传支持所有浏览器,包括ie6,ie7,i ...
- JSP如何实现文件断点上传和断点下载?
核心原理: 该项目核心就是文件分块上传.前后端要高度配合,需要双方约定好一些数据,才能完成大文件分块,我们在项目中要重点解决的以下问题. * 如何分片: * 如何合成一个文件: * 中断了从哪个分片开 ...
- Android中Socket大文件断点上传
原文:http://blog.csdn.net/shimiso/article/details/8529633 什么是Socket? 所谓Socket通常也称作“套接字”,用于描述IP地址和端口,是一 ...
- java文件断点上传
1,项目调研 因为需要研究下断点上传的问题.找了很久终于找到一个比较好的项目. 在GoogleCode上面,代码弄下来超级不方便,还是配置hosts才好,把代码重新上传到了github上面. http ...
随机推荐
- Books Queries (codeforces 1066C)
模拟题 开一个容器进行模拟即可,注意容器设置初始大小不然容易re.设置两个指针l,r.把容器当作桶,每一个桶都有一个编号表示位置,左边进入那么就是编号为l,右边一样.然后l--或者r++,l=r=0的 ...
- Spring MVC 笔记2 HelloWorld
实现这个例子的问题 WEB-INFO目录下必须有spring的包,放在lib下:如下图(这里我直接把idea创建时宣称springmvc,然后把idea给的lib拷贝了下来,也可以的) request ...
- 13.multi_match实现dis_max+tie_breaker
主要知识点: 基于multi_match语法实现dis_max+tie_breaker 1.best_fields+tie_breaker GET /forum/article/_search ...
- Flask - 特殊装饰器 和 Flask工作结构模式(FBV, CBV)
目录 Flask - 特殊装饰器 和 Flask工作结构模式 @app.errorhandler() @app.before_request @app.after_request FBV和CBV Fl ...
- debian 7 安装
1. 从 live cd 或者 dvd 进行安装,官方文档已经够用,可以将 live cd 写进 u 盘,也可以将 dvd 放到硬盘上通过 grub 引导启动安装,文档在这里. 2.安装过程中尽量选择 ...
- hdu 5170 精度控制
众所周知,GTY是一位神犇,为了更好的虐场,他从来不写数学作业而是去屠题,他的数学老师非常不爽,但由于GTY每次考试都AK,她也不能说什么,有一天老师在黑板上写了四个数——a,b,c,da,b,c,d ...
- eclipse 下使用 git
一.默认仓库文件夹 二.window -->perspective --> customize perspective 三.提交时,要忽略的文件
- web项目log日志查看分析->流程理解
1.DEBUG [2017-07-10 11:38:41,705][] org.springframework.web.servlet.DispatcherServlet:865 - Dispatch ...
- HIHO 16 B
卡了~卡了就写不下去了~其实是不会~ 大牛提醒,答案必定是SUM的因子~细细想了好久,才想通~差距~ 因为是所有的和GCD,所以GCD必定整除SUM.. 然后,枚举这些因子,统计前缀和的MOD,看有多 ...
- UVA 12683 Odd and Even Zeroes(数学—找规律)
Time Limit: 1000 MS In mathematics, the factorial of a positive integer number n is written as n! an ...