JS异步文件分片断点上传的实现思路
网络编程 2021-07-04 19:20www.168986.cn编程入门
在项目中有时会遇到大文件上传,经常会出现链接超时的问题,所以就需要使用文件分片上传的方式来上传大文件。狼蚁网站SEO优化通过本文给大家介绍js异步文件分片断点上传的实例代码,需要的的朋友参考下吧
在项目中有时会遇到大文件上传,经常会出现链接超时的问题,所以就需要使用文件分片上传的方式来上传大文件。实现原理就是,在前端将文件分成指定大小的“文件块”,分成多次上传,每次上传前先向后台查询已经上传成功的文件的大小,然后从指定的位置切割一块文件,进行上传,后台接收到文件块后追加到指定的文件中。
这篇博客适合有一些后台基础的朋友,或者有后台配合的前端。
这里需要后台提供两个接口,一个上传文件的接口,一个查询已上传文件大小的接口。
前端代码
这里放上后台主要代码
package .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.RandomAessFile; import java.util.Iterator; import java.util.Map; import javax.annotation.Resource; import javax.servlet.http.HttpServletRequest; import .apache.mons.lang3.StringUtils; import .csource.ClientGlobal; import .csource.mon.MyException; import .csource.fastdfs.FileInfo; import .csource.fastdfs.StorageClient; import .csource.fastdfs.TrackerClient; import .csource.fastdfs.TrackerServer; import .junit.Test; import .springframework.stereotype.Controller; import .springframework.web.bind.annotation.RequestMapping; import .springframework.web.bind.annotation.RequestMethod; import .springframework.web.bind.annotation.ResponseBody; import .springframework.web.multipart.MultipartFile; import .springframework.web.multipart.MultipartHttpServletRequest; import redis.clients.jedis.Jedis; import redis.clients.jedis.JedisShardInfo; import .alibaba.fastjson.JSON; import .fs.entity.UploadedFileInfo; import .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(); } RandomAessFile randomFile = null; try { randomFile = new RandomAessFile(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异步文件分片断点上传的实现思路,希望对大家有所帮助,如果大家有任何疑问请给我留言,长沙网络推广会及时回复大家的。在此也非常感谢大家对狼蚁SEO网站的支持!
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程