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 相关文章推荐
用JS剩余字数计算的代码
Jul 03 Javascript
Ext 今日学习总结
Sep 19 Javascript
JavaScript中清空数组的三种方法分享
Apr 07 Javascript
使用js判断TextBox控件值改变然后出发事件
Mar 07 Javascript
jquery实现华丽的可折角广告代码
Sep 02 Javascript
JS触摸屏网页版仿app弹窗型滚动列表选择器/日期选择器
Oct 30 Javascript
vue中mint-ui环境搭建详细介绍
Apr 06 Javascript
AngularJS之自定义服务详解(factory、service、provider)
Apr 14 Javascript
Angularjs2不同组件间的通信实例代码
May 06 Javascript
vue+webpack模拟后台数据的示例代码
Jul 26 Javascript
小程序如何在不同设备上自适应生成海报的实现方法
Aug 20 Javascript
这样回答继承可能面试官更满意
Dec 10 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
编写PHP的安全策略
2006/10/09 PHP
php 操作调试的方法
2012/07/12 PHP
php+xml实现在线英文词典查询的方法
2015/01/23 PHP
php命令行(cli)模式下报require 加载路径错误的解决方法
2015/11/23 PHP
PHP利用DWZ.CN服务生成短网址
2019/08/11 PHP
PHP执行普通shell命令流程解析
2020/08/24 PHP
jquery 批量上传图片实现代码
2010/01/28 Javascript
jquery 插件学习(二)
2012/08/06 Javascript
js兼容的placeholder属性详解
2013/08/18 Javascript
JQuery文字列表向上滚动的代码
2013/11/13 Javascript
Google Dart编程语法和基本类型学习教程
2013/11/27 Javascript
JavaScript日期类型的一些用法介绍
2015/03/02 Javascript
深入浅析Node.js 事件循环
2015/12/20 Javascript
JavaScript编程中实现对象封装特性的实例讲解
2016/06/24 Javascript
微信小程序 密码输入(源码下载)
2017/06/27 Javascript
jQuery图片缩放插件smartZoom使用实例详解
2017/08/25 jQuery
element 结合vue 在表单验证时有值却提示错误的解决办法
2018/01/22 Javascript
JS从非数组对象转数组的方法小结
2018/03/26 Javascript
Vue隐藏显示、只读实例代码
2018/07/18 Javascript
vscode中vue-cli项目es-lint的配置方法
2018/07/30 Javascript
JavaScript实现的DOM绘制柱状图效果示例
2018/08/08 Javascript
vue-router的使用方法及含参数的配置方法
2018/11/13 Javascript
jQuery实现弹幕特效
2019/11/29 jQuery
[47:20]DAC2018 4.4 淘汰赛 Optic vs Mineski 第一场
2018/04/05 DOTA
python tensorflow基于cnn实现手写数字识别
2018/01/01 Python
基于pytorch的保存和加载模型参数的方法
2019/08/17 Python
使用OpenCV获取图片连通域数量,并用不同颜色标记函
2020/06/04 Python
Scrapy框架介绍之Puppeteer渲染的使用
2020/06/19 Python
Html5页面二次分享的实现
2018/07/30 HTML / CSS
StubHub希腊:购买体育赛事、音乐会和剧院门票
2019/08/03 全球购物
汇智创新科技发展有限公司
2015/12/06 面试题
见习期自我鉴定
2014/01/31 职场文书
2014年民警工作总结
2014/11/25 职场文书
2015年工会工作总结范文
2015/07/23 职场文书
2015中秋节晚会开场白
2015/07/30 职场文书
SQL试题 使用窗口函数选出连续3天登录的用户
2022/04/24 Oracle