news 2026/3/15 3:10:11

网页组件如何集成文件夹上传及分段功能?

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
网页组件如何集成文件夹上传及分段功能?

大文件上传系统开发吐槽日记

甲方爸爸的需求清单

作为一个浙江苦逼的.NET程序员,最近接了个外包项目,甲方爸爸的需求让我差点当场表演"程序员暴毙":

  1. 文件传输:要传20G的文件,还得是文件夹(可能包含1000+文件)
  2. 加密要求:传输要SM4/AES加密,存储也要加密
  3. 断点续传:关浏览器、重启电脑都不能丢进度
  4. 兼容性:从IE8到现代浏览器全都要支持
  5. 预算:100块(我寻思这连服务器一天的电费都不够)
  6. 服务:7*24小时免费技术支持+源码+部署一条龙

技术选型困境

前端方案

// 看到IE8兼容要求时的我functionhandleIe8Compatibility(){if(isIE8()){console.log("建议用户升级浏览器");thrownewError("老板说必须兼容,代码还得写");}}

后端存储方案

// 看到20G文件存储时的数据库设计publicclassFileStorage{// 甲方:就用SQL Server存文件publicvoidStore20GBFile(){// 我的内心:E盘会不会爆炸?varfreeSpace=DriveInfo.GetDrives().First(d=>d.Name=="E").TotalFreeSpace;if(freeSpace<20L*1024*1024*1024){thrownewOutOfDiskSpaceException("甲方爸爸,加个硬盘呗?");}}}

部分实现代码

前端文件上传核心逻辑

// 基于WebUploader的魔改版,兼容IE8(function(){// IE8 polyfill大礼包if(!Array.prototype.forEach){Array.prototype.forEach=function(callback){for(vari=0;i<this.length;i++){callback(this[i],i,this);}};}// 文件夹上传逻辑functionuploadFolder(folder){// 遍历文件夹结构traverseFolder(folder,function(file){// 保持相对路径varrelativePath=getRelativePath(file);// 分片上传uploadFileInChunks(file,relativePath);});}// 断点续传实现functionresumeUpload(fileId){checkServerForProgress(fileId,function(progress){if(progress<100){console.log("从"+progress+"%继续上传");// 继续上传逻辑}});}})();

后端C#处理代码

// 文件上传处理publicclassFileUploadHandler:IHttpHandler{publicvoidProcessRequest(HttpContextcontext){try{// 获取上传文件HttpPostedFilefile=context.Request.Files[0];stringrelativePath=context.Request["relativePath"];// 加密存储using(varcryptoStream=newCryptoStream(File.Create(Path.Combine("E:\\Uploads",relativePath)),newSM4CryptoProvider().CreateEncryptor(),CryptoStreamMode.Write)){file.InputStream.CopyTo(cryptoStream);}// 记录上传进度到数据库RecordUploadProgress(context.Request["fileId"],100);}catch(Exceptionex){// 100块预算的异常处理context.Response.Write("出错啦!但我们没钱修!");}}privatevoidRecordUploadProgress(stringfileId,intprogress){// SQL Server操作using(varconn=newSqlConnection("连不起Azure只能用本地...")){conn.Open();// 省略一万行SQL...}}}

开发者的自我修养

  1. 兼容IE8的绝招

    • 准备大量polyfill
    • 放弃使用任何现代CSS特性
    • 把jQuery 1.x刻进DNA
    • 每晚祈祷用户早日升级
  2. 大文件上传秘籍

    // 分片上传伪代码while(budget<projectCost){Console.WriteLine("再接个外包补这个窟窿");budget+=100;// 每个项目都预算100}
  3. 加密存储小技巧

    // 前端加密演示functionencrypt(data){if(budget>0){returnrealEncrypt(data);// 真加密}else{returndata;// 预算不足时的"加密"}}

项目总结

这个项目教会了我:

  • 如何用100块预算做出10万块的功能
  • 如何在2023年继续伺候IE8这位"老佛爷"
  • 如何在不睡觉的情况下提供7*24支持
  • 为什么程序员会秃头

最终方案:建议甲方加钱,或者我把QQ群(374992201)里的"大神"们介绍给他,毕竟:

  • 加群送红包
  • 推荐有提成
  • “超级会员直接50%提成”
  • 大家一起用爱发电

(免责声明:以上代码仅供娱乐,实际开发请根据预算调整功能范围)

设置框架

安装.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/3/13 15:37:02

基于PLC的恒压供水控制系统西门子s7-1200变频恒压供水系统程序(设计源文件+万字报告+讲解)(支持资料、图片参考_相关定制)_文章底部可以扫码

基于PLC的恒压供水控制系统西门子s7-1200变频恒压供水系统程序(设计源文件万字报告讲解)&#xff08;支持资料、图片参考_相关定制&#xff09;_文章底部可以扫码 1.有动态过程画面仿真和梯形图程序 2.带PID趋势图 3.有图纸(I/O表主电路控制电路图CAD图纸dwg格式&#xff0c;以…

作者头像 李华
网站建设 2026/3/13 18:28:24

1.2 为什么需要RTOS?

1.2 为什么需要RTOS? 1.2.1 前后台系统(超级循环)的基本原理与局限 在资源极其有限或功能极其简单的微控制器(MCU)应用中,一种广泛采用的软件架构是“前后台系统”,也称为“超级循环”(Super Loop)。其核心结构是一个无限循环的主函数(后台),配合中断服务程序(前…

作者头像 李华
网站建设 2026/3/13 10:38:34

医院HIS系统如何集成百度编辑器实现PDF病历跨平台编辑?

Word文档导入与粘贴功能解决方案 项目背景与需求分析 作为安徽某IT公司的.NET工程师&#xff0c;我最近负责在企业网站后台管理系统中增加Word粘贴和文档导入功能。客户的核心需求是&#xff1a; Word粘贴功能&#xff1a;直接从Word复制内容到网站编辑器&#xff0c;图片自…

作者头像 李华
网站建设 2026/3/13 21:50:36

保险网页项目怎么用javascript实现文件夹上传及加密?

大文件传输解决方案技术方案 作为陕西某软件公司项目负责人&#xff0c;针对公司产品部门提出的大文件传输需求&#xff0c;我经过深入调研和技术评估&#xff0c;提出以下专业解决方案。 一、需求分析与技术挑战 核心需求 支持50G以上大文件传输&#xff0c;包含文件/文件…

作者头像 李华
网站建设 2026/3/13 7:26:34

文件时间属性修改神器,绝了

有的时候需要对文件的时间属性进行修改&#xff0c;例如文件的创建时间、访问时间和或者最后的修改时间。 但是Windows系统里面自带的工具没有办法修改这些参数&#xff0c;需要借助第三方软件。今天给大家推荐两款非常强大的软件&#xff0c;可以帮助修改文件时间。 JD Design…

作者头像 李华
网站建设 2026/3/13 8:44:05

25.C++进阶:map|pair类型|构造|增删查|数据修改|迭代器|multimap|OJ

map系列的使⽤ map和multimap参考⽂档 参考文档 map类的介绍 map的声明如下&#xff0c;Key就是map底层关键字的类型&#xff0c;T是map底层value的类型&#xff0c;set默认要求Key⽀持⼩于⽐较&#xff0c;如果不⽀持或者需要的话可以⾃⾏实现仿函数传给第⼆个模版参数&am…

作者头像 李华