SpringBoot集成文件 - 大文件的上传(异步,分片,断点续传和秒传)

上文中介绍的是常规文件的上传和下载,而超大文件的上传技术手段和普通文件上传是有差异的,主要通过基于分片的断点续传和秒传和异步上传等技术手段解决。本文主要介绍SpringBoot集成大文件上传的案例。@pdai

知识准备

大文件的上传技术手段和普通文件上传是有差异的,主要通过基于分片的断点续传和秒传和异步上传解决。@pdai

基于分片的断点续传和秒传

当我们上传的文件很大时,对大文件的处理通常通过分片上传断点续传秒传技术手段实现。

  • 分片上传

分片上传就是将一个大文件分成若干份大小相等的小块文件,等所有小块文件上传成功后,再将文件进行合并成完整的原始文件。

  • 断点续传

断点续传就是重新上传文件时先判断哪些文件块已经上传过了(比如将分片的chuck md5等信息保存在DB中),如果上传过了则跳过这些块,否则上传没有上传的块。

  • 秒传

当用户选择上传一个文件时,服务端检测该文件之前是否已经被上传过,如果服务器已经存有该文件(完全一样),就立马返回前端 “文件已上传成功”。前端随即将进度条更新至100%。 这样给用户的感觉就是 “秒传” 的感觉。

对于分片上传,前后端分别需要怎么做呢

  1. 前端:需要将文件file.slice()成多个文件块,并计算每一块的md5值,每次请求上传都是传一个小文件块。
  2. 后端:需要接收每次上传的文件块并保存文件块的信息(比如md5), 如果已经上传则跳过;最后等所有文件上传完成之后,将所有的文件块合并成一个大文件。

异步上传

当我们上传的文件很大,后台需要处理的时间很长,用户期望切换到其它页面继续工作,而不需要等待完成。这时候我们可以采用异步上传的方式。

在SpringBoot中将一个方法声明为异步方法非常简单,只需两个注解即可@EnableAsync@Async

  1. @EnableAsync用于开启SpringBoot支持异步的功能,用在SpringBoot的启动类上。
@SpringBootApplication
@EnableAsync // 这里
public class App {
 
    public static void main(String[] args) {
        SpringApplication.run(App.class, args);
    }
}
  1. @Async用于方法上,标记该方法为异步处理方法。
@Service
public class UserServiceImpl {
 
    @Async // 这里带@Async的方法,会被当成一个子线程
    public void processFile(InputStream inputStream) {
        
    }
}

实现案例

TBD

示例源码

https://github.com/realpdai/tech-pdai-spring-demos

参考文章

https://www.jb51.net/article/212399.htm