大文件断点续传、快传秒传实现方案

2024-02-03 02:50

本文主要是介绍大文件断点续传、快传秒传实现方案,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言

为什么视频、音频、大型文档等大文件不能也直接上传吗,简单又方便?

遇到手动暂停、网络中断、网络不稳定或者服务端响应超时,当你终于半天到99%,网络突然断开喜提从0%再来一次

再者一次服务接受如此大的数据传输,不说服务器肯同意接收,即使配置同意接受这常常会使服务器出现响应超时或者陷入阻塞。为了解决这些问题,支持断点续传就变得非常必要了

快传、秒传⭐

文件块的上传时计算MD5值,根据MD5去查数据库文件块表,如果存在直接带着查到的记录返回上传成功!!

至于整个大文件是否需要计算MD5来比对数据库文件表,这取决于实际需求来决定。在某些特定场景下,可能需要验证整个大文件的完整性,或者需要将大文件的 MD5 值保存在后端进行后续比对等操作,在这种情况下,就需要计算整个大文件的 MD5 值

(快传、秒传广泛应用于网盘云存储、多平台同步、文件分享和传递、在线备份的场景)

断点续传⭐⭐

将大文件是数据分割为多个相同大小的小片,每个分片带着自己的序号和MD5值独立上传。如果发生事件导致传输中断,下一次传输时重新传输即可,已传输过的分片会根据MD5直接返回传输成功!!

(相同分片大小是为了服务端能够找到该分片在文件写入的起始位置,但是最后一个分片的大小可以小于等于分片大小)

上传流程

这里引入一张较为完整的流程图

细节思路

MD5如何计算 🌙🌙

网上的一种思路MD5(浏览器ID(服务端写在cookie中) + 文件名 + 文件大小 + 文件修改时间 )的格式,进行MD5降重,也避免了MD5计算量大的问题。这种方式适用于个人文件上传的场景,并不适合多平台同步、文件分享传输的场景,因为即使一模一样的两个文件多个用户或者浏览器计算得出的MD5值是不一样的

最好的计算方法是用文件的内容进行MD5计算,但计算量极大,过多的耗时会影响上传的体验,需要尽量控制在MD5计算前限制用户所选文件不能过大

分片的上传方式🌙🌙

先发送一个不携带文件块二进制数据的预检请求,判断文件是否上传完成,分片上传的FormData附带以下参数,序号、总块数、文件ID、分片大小、文件大小、分片的MD5、文件块二进制数据

选择串行还是并发上传,因为js是单线程的无法类似于java线程的方式执行并发上传的任务,但是有一些流行的前端库和框架(如axios、Fetch API、jQuery AJAX等)提供了并发请求的功能,需要注意的是,并发上传可能会对服务器和网络带宽造成一定的负担,对用户体验造成负面影响

分片大小🌙🌙

分片大小的确定一般由前端动态确定,后端还可以根据自身的需求和系统性能,对分片大小进行一定的限制或调整

较大的分片可以提高上传速度,但会增加单个分片上传失败的风险,较小分片可以降低单个分片上传失败的风险,但同时也会提高服务器处理的复杂度

是否需要合并🌙

需要分片合并的场景:服务端每次接收一小片文件保存成一个临时文件,等待所有片段传输完毕后,再执行合并,如果原始文件足够小,只要合理控制分块大小这种方式是可以的,但文件大小达到几百MB或者几个GB,合并文件的时间会非常长,常常导致浏览器响应超时或服务器阻塞,而且服务端会额外多占用一倍的存储空间

如果是每收到分片文件就在文件内指定偏移位置写入的方案,并不需要额外空间保存文件分块,也不需要在上传结束后进行分块的合并

前后端核心方法🌙🌙

JS文件分片的核心方法,   File的slice() 

JAVA写入分片的核心方法, RandomAccessFile的write()  /  MappedByteBuffer的write() 

RandomAccessFile和MapperdByteBuffer都能实现对文件任意位置的读取和写入数据,适用于大文件的读写尤其是频繁读写场景。

两者的不同在于

  • 前者是Java IO提供的类,读写过程中seek()能指定跳转到不同位置,实现随机访问;
  • 后者是Java NIO提供的类,使用内存映射文件的方式将文件的一部分映射到内存中进行读写,这种方式避免传统的IO磁盘操作直接调用系统底层的缓存,没有JVM和系统之间的复制操作,所以效率非常高

代码实现

浏览器端(B/S的B)

  • vue项目实现

npm下载md5工具和vue-upload文件上传插件

  • html的实现

引入一个md5工具

Java客户端(C/S的C)

提供一个文件分割与合并的工具类,使用线程池技术,速度很快

Java服务端(C/S或B/S的S)

提供一个文件分割与合并的工具类,使用线程池技术,速度很快

SpringBoot中普通文件上传存储代码见上篇博客:SpringBoot文件上传存储解决方案_springboot 文件存储-CSDN博客使用Spring Boot框架实现一个完善的文件上传功能,在Spring Boot中配置文件上传的方法,并提供了详细的代码说明。通过学习本文,你将获得实战经验,能够快速应用文件上传功能在自己的项目中。如果你对Spring Boot文件上传感兴趣,那么这篇文章将为你提供一套较为完善的解决方案,助你快速搭建和应用文件上传功能,并且具备很大的扩展性。_springboot 文件存储https://blog.csdn.net/util123/article/details/131786587?spm=1001.2014.3001.5502

代码资源自取,学习用

这篇关于大文件断点续传、快传秒传实现方案的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/672780

相关文章

Flutter实现文字镂空效果的详细步骤

《Flutter实现文字镂空效果的详细步骤》:本文主要介绍如何使用Flutter实现文字镂空效果,包括创建基础应用结构、实现自定义绘制器、构建UI界面以及实现颜色选择按钮等步骤,并详细解析了混合模... 目录引言实现原理开始实现步骤1:创建基础应用结构步骤2:创建主屏幕步骤3:实现自定义绘制器步骤4:构建U

SpringBoot中四种AOP实战应用场景及代码实现

《SpringBoot中四种AOP实战应用场景及代码实现》面向切面编程(AOP)是Spring框架的核心功能之一,它通过预编译和运行期动态代理实现程序功能的统一维护,在SpringBoot应用中,AO... 目录引言场景一:日志记录与性能监控业务需求实现方案使用示例扩展:MDC实现请求跟踪场景二:权限控制与

Android实现定时任务的几种方式汇总(附源码)

《Android实现定时任务的几种方式汇总(附源码)》在Android应用中,定时任务(ScheduledTask)的需求几乎无处不在:从定时刷新数据、定时备份、定时推送通知,到夜间静默下载、循环执行... 目录一、项目介绍1. 背景与意义二、相关基础知识与系统约束三、方案一:Handler.postDel

电脑找不到mfc90u.dll文件怎么办? 系统报错mfc90u.dll丢失修复的5种方案

《电脑找不到mfc90u.dll文件怎么办?系统报错mfc90u.dll丢失修复的5种方案》在我们日常使用电脑的过程中,可能会遇到一些软件或系统错误,其中之一就是mfc90u.dll丢失,那么,mf... 在大部分情况下出现我们运行或安装软件,游戏出现提示丢失某些DLL文件或OCX文件的原因可能是原始安装包

电脑显示mfc100u.dll丢失怎么办?系统报错mfc90u.dll丢失5种修复方案

《电脑显示mfc100u.dll丢失怎么办?系统报错mfc90u.dll丢失5种修复方案》最近有不少兄弟反映,电脑突然弹出“mfc100u.dll已加载,但找不到入口点”的错误提示,导致一些程序无法正... 在计算机使用过程中,我们经常会遇到一些错误提示,其中最常见的就是“找不到指定的模块”或“缺少某个DL

使用Python实现IP地址和端口状态检测与监控

《使用Python实现IP地址和端口状态检测与监控》在网络运维和服务器管理中,IP地址和端口的可用性监控是保障业务连续性的基础需求,本文将带你用Python从零打造一个高可用IP监控系统,感兴趣的小伙... 目录概述:为什么需要IP监控系统使用步骤说明1. 环境准备2. 系统部署3. 核心功能配置系统效果展

Python实现微信自动锁定工具

《Python实现微信自动锁定工具》在数字化办公时代,微信已成为职场沟通的重要工具,但临时离开时忘记锁屏可能导致敏感信息泄露,下面我们就来看看如何使用Python打造一个微信自动锁定工具吧... 目录引言:当微信隐私遇到自动化守护效果展示核心功能全景图技术亮点深度解析1. 无操作检测引擎2. 微信路径智能获

Python中pywin32 常用窗口操作的实现

《Python中pywin32常用窗口操作的实现》本文主要介绍了Python中pywin32常用窗口操作的实现,pywin32主要的作用是供Python开发者快速调用WindowsAPI的一个... 目录获取窗口句柄获取最前端窗口句柄获取指定坐标处的窗口根据窗口的完整标题匹配获取句柄根据窗口的类别匹配获取句

在 Spring Boot 中实现异常处理最佳实践

《在SpringBoot中实现异常处理最佳实践》本文介绍如何在SpringBoot中实现异常处理,涵盖核心概念、实现方法、与先前查询的集成、性能分析、常见问题和最佳实践,感兴趣的朋友一起看看吧... 目录一、Spring Boot 异常处理的背景与核心概念1.1 为什么需要异常处理?1.2 Spring B

Python位移操作和位运算的实现示例

《Python位移操作和位运算的实现示例》本文主要介绍了Python位移操作和位运算的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录1. 位移操作1.1 左移操作 (<<)1.2 右移操作 (>>)注意事项:2. 位运算2.1