news 2026/5/25 17:43:06

.NET WebForm如何整合第三方组件支持大文件断点续传?

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
.NET WebForm如何整合第三方组件支持大文件断点续传?

开发者日记:大文件传输系统开发历程

2023年11月15日 多云转晴

今天接手了一个颇具挑战性的外包项目 - 基于浏览器的超大文件传输系统。客户要求异常严格,必须支持20G文件的断点续传,还要兼容IE8这种"古董"浏览器。作为一名在安徽独立打拼的开发者,这既是一次机会也是一次考验。

技术方案分析

经过一整天的调研,我确定了以下技术路线:

  1. 前端方案:由于需要兼容IE8,Vue3只能作为渐进增强方案,核心功能必须使用原生JS实现。文件夹结构保留将通过webkitdirectory属性配合自定义目录结构算法实现。

  2. 加密方案:采用国密SM4为主,AES-256为辅的混合加密策略。SM4更适合国内环境,而AES则提供更广泛的兼容性。

  3. 断点续传:需要在客户端存储分片信息,使用IndexedDB+localStorage的降级方案,确保IE8也能工作。

  4. 后端存储:阿里云OSS直接存储加密后的文件,数据库只记录元数据和分片信息。

部分核心代码实现

前端文件选择处理 (原生JS)
// 文件选择处理器 - 兼容IE8和其他现代浏览器functionhandleFileSelect(event){constfiles=event.target.files;constitems=event.dataTransfer?event.dataTransfer.items:null;// 处理文件夹上传if(items&&items[0].webkitGetAsEntry){processDirectoryEntries(items);}else{// 普通文件处理processFiles(files);}}// 递归处理目录结构functionprocessDirectoryEntries(items){for(leti=0;i<items.length;i++){constentry=items[i].webkitGetAsEntry();if(entry.isFile){entry.file(file=>{file.fullPath=entry.fullPath||file.name;addFileToQueue(file);});}elseif(entry.isDirectory){constdirReader=entry.createReader();dirReader.readEntries(entries=>{processDirectoryEntries(entries);});}}}
后端分片上传接口 (ASP.NET Core)
[ApiController][Route("api/upload")]publicclassUploadController:ControllerBase{privatereadonlyIUploadService_uploadService;publicUploadController(IUploadServiceuploadService){_uploadService=uploadService;}[HttpPost("chunk")]publicasyncTaskUploadChunk([FromForm]ChunkUploadRequestrequest){try{varresult=await_uploadService.ProcessChunkAsync(request);returnOk(result);}catch(Exceptionex){returnStatusCode(500,new{error=ex.Message});}}}publicclassChunkUploadRequest{publicstringFileId{get;set;}publicintChunkNumber{get;set;}publicintTotalChunks{get;set;}publicstringFileName{get;set;}publicstringRelativePath{get;set;}// 保留文件夹结构publicIFormFileFile{get;set;}publicstringHash{get;set;}}
加密工具类 (SM4实现)
publicstaticclassSM4Util{privatestaticreadonlyEncodingEncoding=Encoding.UTF8;publicstaticstringEncrypt(stringplainText,stringkey){varsm4=newSM4();varencrypted=sm4.EncryptECB(Encoding.GetBytes(plainText),Encoding.GetBytes(key));returnConvert.ToBase64String(encrypted);}publicstaticstringDecrypt(stringcipherText,stringkey){varsm4=newSM4();vardecrypted=sm4.DecryptECB(Convert.FromBase64String(cipherText),Encoding.GetBytes(key));returnEncoding.GetString(decrypted);}}

IE8兼容方案

这可能是最具挑战的部分。我需要实现一个降级方案:

  1. Flash/ActiveX备用方案:当检测到IE8时,加载备用上传器
  2. 分片上传:即使使用Flash也要支持
  3. 进度存储:使用cookie和userData行为存储进度
// 检测IE8并加载备用上传器if(document.documentMode&&document.documentMode<=8){loadLegacyUploader();}functionloadLegacyUploader(){// 使用Flash或Silverlight实现上传功能varswfUrl="/Content/Uploader.swf";swfobject.embedSWF(swfUrl,"uploadContainer","100%","400","10.0.0");}

明日计划

  1. 完成文件夹结构递归算法的测试
  2. 实现IE8下的分片上传功能
  3. 编写SQL Server存储过程,优化大容量数据存储

这个项目虽然挑战巨大,但恰好能检验我多年的全栈开发经验。如果能顺利完成,不仅能帮助客户解决实际问题,也能为我的技术履历添上浓墨重彩的一笔。

设置框架

目标框架选择 .NET 8.0

IDE使用Visual Studio 2022

编译项目

修改测试端口

修改项目测试端口,根据客户服务器环境修改。不一定是示例中的端口。

访问测试页面

测试一下配置是否正确。

NOSQL

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

创建数据库

连接数据库

数据表

检查创建的数据表,数据表创建成功后可以在数据库下面的表节点中看到

查询数据

配置数据库连接信息

检查数据库配置

访问页面进行测试

效果预览

文件上传

文件刷新续传

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

文件夹上传

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

下载完整示例

已经上传到gitee了,可以直接下载

下载完整示例

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

整数数组匹配

有两个数组a和b数组&#xff0c;都是正数的数组&#xff0c;a的数组总和在b数组中哪一块连续的空间差值最小&#xff0c;如果找到了&#xff0c;就打印b数组中的数组元素&#xff0c;首先解决这个问题需要有两个数组&#xff0c;还需要把a数组的总和求出来&#xff0c;求出来以…

作者头像 李华
网站建设 2026/5/25 14:41:22

Open-AutoGLM任务流程中断恢复实战(9大断点场景与恢复策略全曝光)

第一章&#xff1a;Open-AutoGLM任务流程中断恢复概述在大规模语言模型自动化推理与生成任务中&#xff0c;Open-AutoGLM 的执行流程常因资源调度、网络波动或系统异常而中断。为保障任务的可靠性与数据一致性&#xff0c;设计一套完整的流程中断恢复机制至关重要。该机制需支持…

作者头像 李华
网站建设 2026/5/4 4:05:57

Open-AutoGLM如何实现大模型压缩3倍性能不减?一文讲透核心技术路径

第一章&#xff1a;Open-AutoGLM 大模型轻量化协同 在大模型快速发展的背景下&#xff0c;Open-AutoGLM 作为一种面向高效推理与分布式训练优化的轻量化协同框架&#xff0c;致力于解决传统大模型部署中资源消耗高、响应延迟大等问题。该框架通过动态剪枝、量化感知训练与知识蒸…

作者头像 李华
网站建设 2026/5/21 20:43:58

56、Windows系统文件权限与加密管理全攻略

Windows系统文件权限与加密管理全攻略 1. 从命令行获取文件所有权 在Windows系统中,通过层层窗口来获取文件所有权,然后再关闭这些窗口,接着重新打开以更改权限,这一过程十分繁琐。如果你熟悉命令提示符,或者需要通过脚本获取所有权,Windows 7提供了一些实用工具。 - …

作者头像 李华
网站建设 2026/5/22 4:35:20

2、Windows 7使用指南:特性、版本差异与64位选择

Windows 7使用指南:特性、版本差异与64位选择 1. Windows 7概述 Windows 7在性能和功能上相较于其前身Windows Vista有显著提升,运行速度更快,用户账户控制(UAC)系统也更为智能且可定制。新的任务栏设计将打开和未运行的应用程序图标并列显示,类似Mac OS X的Dock,还配…

作者头像 李华
网站建设 2026/5/23 6:24:50

揭秘Open-AutoGLM任务中断黑盒:如何在5分钟内精准定位并恢复执行流

第一章&#xff1a;揭秘Open-AutoGLM任务中断黑盒在部署和运行 Open-AutoGLM 模型任务时&#xff0c;任务意外中断成为开发者频繁遭遇的痛点。这类问题往往缺乏明确日志提示&#xff0c;形成“黑盒”现象&#xff0c;严重阻碍自动化流程的稳定性。中断常见触发因素 资源超限&am…

作者头像 李华