在项目中有时会遇到大文件上传,经常会出现链接超时的问题,所以就需要使用文件分片上传的方式来上传大文件。实现原理就是,在前端将文件分成指定大小的“文件块”,分成多次上传,每次上传前先向后台查询已经上传成功的文件的大小,然后从指定的位置切割一块文件,进行上传,后台接收到文件块后追加到指定的文件中。
这篇博客适合有一些后台基础的朋友,或者有后台配合的前端。
这里需要后台提供两个接口,一个上传文件的接口,一个查询已上传文件大小的接口。
前端代码:https://github.com/li5454yong/FileUpload.git
这里放上后台主要代码
package com.fs.controller;import java.io.File; import java.io.FileInputStream; import java.io.FileOutputStream; import java.io.FileWriter; import java.io.IOException; import java.io.InputStream; import java.io.RandomAccessFile; import java.util.Iterator; import java.util.Map; import javax.annotation.Resource; import javax.servlet.http.HttpServletRequest; import org.apache.commons.lang3.StringUtils; import org.csource.ClientGlobal; import org.csource.common.MyException; import org.csource.fastdfs.FileInfo; import org.csource.fastdfs.StorageClient; import org.csource.fastdfs.TrackerClient; import org.csource.fastdfs.TrackerServer; import org.junit.Test; 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.ResponseBody; import org.springframework.web.multipart.MultipartFile; import org.springframework.web.multipart.MultipartHttpServletRequest; import redis.clients.jedis.Jedis; import redis.clients.jedis.JedisShardInfo; import com.alibaba.fastjson.JSON; import com.fs.entity.UploadedFileInfo; import com.fs.util.UploadUtil; /** * @author admin * * 2016年12月20日下午8:59:38 */ @Controller public class FastDFSUpLoadController { @Resource private UploadUtil uploadUtil; @RequestMapping(value = "v1/uploadSize", method = RequestMethod.POST) @ResponseBody public Long uploadSize(HttpServletRequest request) { String name = request.getParameter("name"); Long size = Long.parseLong(request.getParameter("size")); try { JedisShardInfo jedisShardInfo = new JedisShardInfo("192.168.0.12"); Jedis jedis = new Jedis(jedisShardInfo); String str = jedis.get(name); UploadedFileInfo uploadedFileInfo = null; // 如果首次上传,已上传大小为 0 if (StringUtils.isEmpty(str)) { uploadedFileInfo = new UploadedFileInfo(); jedis.set(name, JSON.toJSONString(uploadedFileInfo)); jedis.close(); return 0L; } uploadedFileInfo = JSON.parseObject(str, UploadedFileInfo.class); jedis.close(); //已经全部上传 if(size <= uploadedFileInfo.getSize()){ System.out.println("上传完成"); } //UploadUtil.getFileInfo(uploadedFileInfo.getFileId()); return uploadedFileInfo.getSize(); } catch (Exception e) { e.printStackTrace(); return 0L; } } @RequestMapping(value = "v1/uploadFile", method = RequestMethod.POST) @ResponseBody public int upload(HttpServletRequest request) { // CommonsMultipartResolver resolver = new // CommonsMultipartResolver(request.getSession().getServletContext()); MultipartHttpServletRequest multiRequest = (MultipartHttpServletRequest) request; Iterator<String> t = multiRequest.getFileNames(); MultipartFile fileDetail = multiRequest.getFile(t.next()); String name = request.getParameter("name"); JedisShardInfo jedisShardInfo = new JedisShardInfo("192.168.0.12"); Jedis jedis = new Jedis(jedisShardInfo); UploadedFileInfo uploadedFileInfo = JSON.parseObject(jedis.get(name), UploadedFileInfo.class); uploadedFileInfo.setFileName(name); String path = "d:/testUpload"; File file = new File(path); if (!file.exists() && !file.isDirectory()) { boolean b = file.mkdirs(); } RandomAccessFile randomFile = null; try { randomFile = new RandomAccessFile(path+"/"+name, "rw"); randomFile.seek(randomFile.length()); randomFile.write(fileDetail.getBytes()); uploadedFileInfo.setLocalPath(path+"/"+name); uploadedFileInfo.setSize(randomFile.length()); } catch (IOException e) { e.printStackTrace(); }finally{ try { randomFile.close(); } catch (IOException e) { e.printStackTrace(); } } // 将上传文件信息保存到redis jedis.set(name, JSON.toJSONString(uploadedFileInfo)); jedis.close(); return 0; } }
以上所述是小编给大家介绍的JS异步文件分片断点上传的实现思路,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
标签:
js,异步上传,js,断点上传
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
暂无“JS异步文件分片断点上传的实现思路”评论...
P70系列延期,华为新旗舰将在下月发布
3月20日消息,近期博主@数码闲聊站 透露,原定三月份发布的华为新旗舰P70系列延期发布,预计4月份上市。
而博主@定焦数码 爆料,华为的P70系列在定位上已经超过了Mate60,成为了重要的旗舰系列之一。它肩负着重返影像领域顶尖的使命。那么这次P70会带来哪些令人惊艳的创新呢?
根据目前爆料的消息来看,华为P70系列将推出三个版本,其中P70和P70 Pro采用了三角形的摄像头模组设计,而P70 Art则采用了与上一代P60 Art相似的不规则形状设计。这样的外观是否好看见仁见智,但辨识度绝对拉满。
更新动态
2024年05月09日
2024年05月09日
- 群星《妖神令 影视原声专辑》[320K/MP3][85.23MB]
- 逆水寒手游五子棋第二十三关怎么过 逆水寒手游残局攻略大全
- 逆水寒手游五子棋第二十二关怎么过 逆水寒手游残局攻略大全
- 欢乐钓鱼大师最稀有的鱼是什么 欢乐钓鱼大师最稀有的鱼攻略
- ABC唱片-《蔡琴.三十周年纪念版》6N纯银镀膜[WAV+CUE]
- ABC唱片-《汉斯.德斯辛克.心中布鲁斯》6N纯银镀膜[WAV+CUE]
- 群星《DJ·夜色魅影HQ》头版限量[低速原抓WAV+CUE]
- 《如龙》桐生声优被警察拦下盘问:你有犯罪记录吗?
- 游族2023年净利润0.91亿元 《少年西游记2》即将公测
- 曝快手北京游戏事业部全数被裁 项目测试数据未达标
- 李雨寰.2012-我可是天使【有凰音乐】【WAV+CUE】
- 刘美君.1991-听我细诉【BMG】【WAV+CUE】
- 群星.2016-滚石爱情故事3CD【滚石】【WAV+CUE】
- 欢乐钓鱼大师怎么解锁全地图 欢乐钓鱼大师全地图解锁方法
- 欢乐钓鱼大师锦标赛在哪里进 欢乐钓鱼大师锦标赛入口位置介绍