news 2026/6/10 14:11:44

如何利用jQuery实现大文件的分片上传和断点续传?

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
如何利用jQuery实现大文件的分片上传和断点续传?

2023年X月X日 开发日志 - 大文件传输系统攻坚实录

凌晨1:30,合肥的暴雨敲打着窗户,我正在为这个极具挑战的外包项目设计技术方案。客户的需求相当硬核——基于WebUploader实现20G级文件夹传输,还要兼容IE8这个"上古神器"。泡了杯浓茶,记录下今天的突破性进展。


核心问题拆解

  1. 文件夹结构保持:WebUploader原生只支持文件选择
  2. IE8兼容性:现代API如FileSystem API完全不可用
  3. 断点持久化:需要跨越浏览器会话的进度保存
  4. 非打包下载:避免服务器压缩数万文件的性能灾难

关键技术突破

1. 文件夹结构采集方案

通过分析Windows/MacOS的目录选择行为,发现隐藏的webkitdirectory属性:

配套的Vue3处理逻辑:

// folder-processor.jsexportconstscanFolder=(entries,path='')=>{constitems=[]for(constentryofentries){constitem={path:path+entry.name,isFile:entry.isFile}if(entry.isFile){item.file=entry items.push(item)}else{items.push({...item,children:awaitscanFolder(awaitreadDirectory(entry),path+entry.name+'/')})}}returnitems}
2. 断点续传持久化设计

采用三级缓存机制确保可靠性:

  1. IndexedDB:存储分片二进制数据(现代浏览器)
  2. localStorage:存储元信息(兼容IE8)
  3. 服务端校验:最终一致性保障
// C# 断点状态服务publicclassUploadStateService{privatereadonlystring_connStr;publicasyncTaskGetStateAsync(stringfileKey){usingvarconn=newSqlConnection(_connStr);returnawaitconn.QueryFirstOrDefaultAsync(@"SELECT * FROM UploadStates WHERE FileKey = @fileKey AND UserId = @userId",new{fileKey,UserContext.Current.UserId});}publicasyncTaskSaveChunkAsync(FileChunkchunk){// 采用UPSERT模式varsql=@" MERGE INTO UploadChunks AS target USING (VALUES (@chunkId, @fileKey, @chunkNumber)) AS source(...) ON target.ChunkId = source.chunkId WHEN MATCHED THEN UPDATE SET ... WHEN NOT MATCHED THEN INSERT (...) VALUES (...)";awaitconn.ExecuteAsync(sql,chunk);}}
3. 非打包下载实现

利用阿里云OSS的列举和签名机制:

// FileController.cs[HttpGet("download")]publicasyncTaskDownloadFolder(stringpath){varobjects=await_ossService.ListObjectsAsync(path);varmanifest=objects.Select(o=>new{Key=o.Key,Url=_ossService.GeneratePresignedUrl(o.Key)});returnJson(new{Type="folder",Manifest=manifest,BasePath=path});}

前端处理逻辑:

// download-manager.jsexportconstdownloadFolder=async(manifest)=>{for(constitemofmanifest){constrelativePath=item.Key.replace(manifest.BasePath,'')awaitcreateLocalDirectory(relativePath)constresponse=awaitfetch(item.Url)constblob=awaitresponse.blob()saveAs(blob,relativePath.split('/').pop())}}

IE8兼容性魔改实录

在QQ群(374992201)里与几位前辈探讨后,采用以下黑科技:

// ie8-compat.jsdocument.attachEvent('onclick',function(){if(window.ActiveXObject){// 使用古老的FileSystemObjectvarfso=newActiveXObject("Scripting.FileSystemObject")varfolder=fso.GetFolder(selectedPath)traverseFolder(folder)}})functiontraverseFolder(folder){varfiles=newEnumerator(folder.files)for(;!files.atEnd();files.moveNext()){postFile(files.item())}varsubfolders=newEnumerator(folder.subfolders)for(;!subfolders.atEnd();subfolders.moveNext()){traverseFolder(subfolders.item())}}

项目进度与反思

  • ✅ 已完成:
    • 文件夹元数据采集方案
    • 基础分片上传功能
  • ⏳ 进行中:
    • 断点状态同步逻辑
    • OSS直传优化
  • ❗ 风险点:
    • IE8的ActiveX安全策略可能导致功能受限
    • 超深层级文件夹的性能问题

深夜的键盘声格外清晰,这个项目让我深刻体会到——兼容IE8就像考古学家修复青铜器,需要特殊的工具和极大的耐心。明天将继续完善分片合并逻辑,或许该考虑引入Web Worker来避免界面卡顿…

(文档持续更新中,完整代码请关注QQ群文件更新)

设置框架

安装.NET Framework 4.7.2
https://dotnet.microsoft.com/en-us/download/dotnet-framework/net472
框架选择4.7.2

添加3rd引用

编译项目

NOSQL

NOSQL无需任何配置可直接访问页面进行测试

SQL

使用IIS
大文件上传测试推荐使用IIS以获取更高性能。

使用IIS Express

小文件上传测试可以使用IIS Express

创建数据库

配置数据库连接信息

检查数据库配置

访问页面进行测试


相关参考:
文件保存位置,

效果预览

文件上传

文件刷新续传

支持离线保存文件进度,在关闭浏览器,刷新浏览器后进行不丢失,仍然能够继续上传

文件夹上传

支持上传文件夹并保留层级结构,同样支持进度信息离线保存,刷新页面,关闭页面,重启系统不丢失上传进度。

下载完整示例

下载完整示例

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/1 2:51:29

Ollama部署ChatGLM3-6B-128K:支持RAG增强的长文本问答系统搭建指南

Ollama部署ChatGLM3-6B-128K:支持RAG增强的长文本问答系统搭建指南 1. 为什么需要ChatGLM3-6B-128K这样的长文本模型 你有没有遇到过这样的问题:手头有一份50页的技术白皮书、一份上万字的合同草案,或者几十页的产品需求文档,想…

作者头像 李华
网站建设 2026/6/5 21:01:12

通义千问2.5-7B镜像测评:vLLM高吞吐部署实测表现

通义千问2.5-7B镜像测评:vLLM高吞吐部署实测表现 最近在折腾大模型本地部署,发现阿里新出的通义千问2.5-7B-Instruct模型挺有意思。这个70亿参数的模型号称是“中等体量、全能型、可商用”,听起来挺吸引人。正好手头有台服务器,就…

作者头像 李华
网站建设 2026/6/6 17:55:51

AI写论文大赏!这4个AI论文写作工具,为毕业论文保驾护航!

写期刊论文是不是让你感到很烦恼? 海量的文献、复杂的格式,还有不断的修改,效率低下似乎成了许多学术人员的共同问题!别担心,接下来我会推荐4款实测好用的AI论文写作工具,帮助你从文献检索、生成论文大纲&…

作者头像 李华
网站建设 2026/6/10 12:37:38

开题卡住了?千笔ai写作,本科生论文救星

你是否曾为论文选题发愁,反复修改却依然找不到方向?是否在文献检索中迷失,在格式调整中崩溃,又在查重率面前焦虑不安?对于许多本科生来说,论文写作就像一场孤独的战役,既需要灵感,又…

作者头像 李华
网站建设 2026/6/10 10:54:01

Nano-Banana与SpringBoot集成:构建拆解微服务系统

Nano-Banana与SpringBoot集成:构建拆解微服务系统 1. 为什么需要把拆解能力变成微服务 最近在星图GPU平台上试用🖥Nano-Banana: 结构拆解实验室镜像时,发现一个很实际的问题:团队里不同角色对拆解能力的需求完全不同。设计师想快…

作者头像 李华
网站建设 2026/6/10 10:54:00

SenseVoice Small镜像实操手册:支持wav/mp3/m4a/flac的全格式转写

SenseVoice Small镜像实操手册:支持wav/mp3/m4a/flac的全格式转写 1. 什么是SenseVoice Small? SenseVoice Small是阿里通义实验室推出的轻量级语音识别模型,专为日常听写、会议记录、课程整理等高频语音转文字场景设计。它不是动辄几GB的大…

作者头像 李华