JS异步文件分片断点上传的实现思路


Posted in Javascript onDecember 25, 2016

在项目中有时会遇到大文件上传,经常会出现链接超时的问题,所以就需要使用文件分片上传的方式来上传大文件。实现原理就是,在前端将文件分成指定大小的“文件块”,分成多次上传,每次上传前先向后台查询已经上传成功的文件的大小,然后从指定的位置切割一块文件,进行上传,后台接收到文件块后追加到指定的文件中。

这篇博客适合有一些后台基础的朋友,或者有后台配合的前端。

这里需要后台提供两个接口,一个上传文件的接口,一个查询已上传文件大小的接口。

JS异步文件分片断点上传的实现思路

前端代码: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异步文件分片断点上传的实现思路,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
WEB 浏览器兼容 推荐收藏
May 14 Javascript
javascript中的继承实例代码
Apr 27 Javascript
js原生态函数中使用jQuery中的 $(this)无效的解决方法
May 25 Javascript
JavaScript中valueOf函数与toString方法深入理解
Dec 02 Javascript
js获取当前地址 JS获取当前URL的示例代码
Feb 26 Javascript
button没写type=button会导致点击时提交
Mar 06 Javascript
处理文本部分内容的TextRange对象应用实例
Jul 29 Javascript
JavaScript中的Math.sin()方法使用详解
Jun 15 Javascript
Bootstrap+jfinal实现省市级联下拉菜单
May 30 Javascript
vue将单页面改造成多页面应用的方法
Nov 25 Javascript
原生js实现随机点餐效果
Dec 10 Javascript
微信小程序自定义弹出层效果
May 26 Javascript
BootStrop前端框架入门教程详解
Dec 25 #Javascript
半个小时学json(json传递示例)
Dec 25 #Javascript
在DWR中实现直接获取一个JAVA类的返回值的两种方法
Dec 25 #Javascript
JS如何生成一个不重复的ID的函数
Dec 25 #Javascript
js Canvas实现的日历时钟案例分享
Dec 25 #Javascript
ES6概念 Symbol toString()方法
Dec 25 #Javascript
ES6概念 Symbol.keyFor()方法
Dec 25 #Javascript
You might like
为什么《星际争霸》是测试人工智能的理想战场
2019/12/03 星际争霸
玩转虚拟域名◎+ .
2006/10/09 PHP
PHP Socket 编程
2010/04/09 PHP
php 变量未定义等错误的解决方法
2011/01/12 PHP
php模拟js函数unescape的函数代码
2012/10/20 PHP
无需数据库在线投票调查php代码
2016/07/20 PHP
PHP读取大文件的几种方法介绍
2016/10/27 PHP
PHP面向对象程序设计之类与反射API详解
2016/12/02 PHP
Laravel中9个不经常用的小技巧汇总
2019/04/16 PHP
Laravel 微信小程序后端搭建步骤详解
2019/11/26 PHP
javascript 有趣而诡异的数组
2009/04/06 Javascript
javascript HTMLEncode HTMLDecode的完整实例(兼容ie和火狐)
2009/06/02 Javascript
JS获取下拉框显示值和判断单选按钮的方法
2015/07/09 Javascript
JS实现的通用表单验证插件完整实例
2015/08/20 Javascript
详解Node.js串行化流程控制
2017/05/04 Javascript
vue如何获取点击事件源的方法
2017/08/10 Javascript
详解在Vue中有条件地使用CSS类
2017/09/30 Javascript
vue实现重置表单信息为空的方法
2018/09/29 Javascript
vscode中Vue别名路径提示的实现
2020/07/31 Javascript
Vue单页面应用中实现Markdown渲染
2021/02/14 Vue.js
[33:09]完美世界DOTA2联赛循环赛 Forest vs DM BO2第二场 10.29
2020/10/29 DOTA
Python 将RGB图像转换为Pytho灰度图像的实例
2017/11/14 Python
python安装教程
2018/02/28 Python
flask框架中勾子函数的使用详解
2018/08/01 Python
python3实现爬取淘宝美食代码分享
2018/09/23 Python
对Python捕获控制台输出流的方法详解
2019/01/07 Python
Python求均值,方差,标准差的实例
2019/06/29 Python
python 数据库查询返回list或tuple实例
2020/05/15 Python
python中的错误如何查看
2020/07/08 Python
美国知名艺术画网站:Art.com
2017/02/09 全球购物
中药专业大学生医药工作求职信
2013/10/25 职场文书
新品发布会策划方案
2014/06/08 职场文书
田径运动会通讯稿
2014/09/13 职场文书
文明礼仪倡议书
2015/04/28 职场文书
餐馆开业致辞
2015/08/01 职场文书
Java常用函数式接口总结
2021/06/29 Java/Android