news 2026/4/16 11:54:25

jQuery如何实现网页大文件上传的进度回传功能?

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
jQuery如何实现网页大文件上传的进度回传功能?

.NET程序员的20G文件上传历险记

大家好,我是甘肃的一名苦逼.NET程序员,最近接了个外包项目,客户的需求简直是要我老命啊!来给大家扒一扒这个"价值连城"的项目需求:

项目需求:地狱级难度

  1. 大文件上传:20G!不是20M也不是2G,是20G!想想我的小水管服务器就瑟瑟发抖
  2. 兼容性要求:从IE8到现代浏览器全都要支持 - “总不能把业务机器扔掉吧”,客户原话
  3. 文件夹结构保留:用户上传的文件夹可能有1000个分类文件,还得保持层级
  4. 断点续传:关了浏览器、重启电脑都不能丢进度 - 这得用上黑魔法吧?
  5. 加密要求:SM4、AES全都要,传输存储都要加密
  6. 预算:100元以内!还要求7×24小时技术支持、源代码、打包部署一条龙…

技术选型:在夹缝中求生存

既然客户点名要WebUploader或原生JS,预算又这么"慷慨",我只能选择…

// 前端伪代码 - 用生命在兼容IE8varie8Flag=/*@cc_on!@*/false;// 判断IE8的黑魔法if(ie8Flag){alert("亲,您还在用IE8啊?给您磕头了!");// 这里要写一堆ActiveX和VBScript的兼容代码}else{// 现代浏览器可以用File API}

文件夹上传的坑

网上找的代码大多只支持文件上传,文件夹上传保留层级结构?自己造轮子吧!

// 后端C#处理文件夹结构的伪代码publicvoidHandleFolderUpload(HttpPostedFilefile,stringrelativePath){// relativePath是前端传来的文件夹相对路径stringserverPath=Path.Combine("E:\\Uploads",relativePath);Directory.CreateDirectory(Path.GetDirectoryName(serverPath));file.SaveAs(serverPath);// 预算只够写伪代码了,真实项目这里还要处理各种异常}

断点续传实现思路

  1. 前端分片计算文件哈希作为唯一标识
  2. 后端记录已上传的分片信息
  3. 用户中断后重新上传时,先查询已上传分片
// 前端断点续传逻辑functionresumeUpload(file){calculateFileHash(file).then(hash=>{$.get("/api/upload/progress?hash="+hash,function(data){// data返回已上传的分片列表uploadRemainingChunks(file,data.uploadedChunks);});});}

加密传输方案

// C# SM4加密示例(简化版)publicstringSM4Encrypt(stringinput,stringkey){// 这里应该是复杂的SM4算法实现// 但预算只够写个伪代码...return"加密后的"+input+"(假装加密了)";}

现实与理想的差距

客户:“这个功能很简单吧,几天能做完?”
我:(内心OS)几天?给我几个月还差不多…
表面:“这个…我需要评估一下技术可行性…”

给同行们的忠告

  1. 接单前一定要评估需求合理性
  2. IE8支持真的是个大坑,能推就推
  3. 文件夹上传保留层级不是那么简单
  4. 100元预算做这种需求…不如去要饭

最后说点掏心窝子的话

各位同行啊,咱们程序员也要硬气一点。这种明显不合理的需求,要么加钱,要么拒绝。别为了接单把自己逼到绝路。

至于那个QQ群广告…咳咳,大家自己判断吧。反正我是不信什么"2万项目提成1万"的好事。真有这种好事,他们为什么不自己接单呢?

最后的最后:如果你真的非要做这个项目,我建议:

  1. 先和客户重新谈需求和预算
  2. 实在不行就用现成的商业解决方案(虽然超预算)
  3. 真要自己实现,做好加班到秃顶的准备

祝你好运吧,甘肃的程序员兄弟!

设置框架

安装.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/4/2 15:27:05

Spring-AI系列——Tool Calling获取当前时间

文章目录一、调用流程二、代码tool包下的TimeTools.java类controller.ZhipuChatClientController.java三、效果四、底层调用情况一、调用流程 二、代码 tool包下的TimeTools.java类 package org.example.tool;import org.springframework.ai.tool.annotation.Tool; import or…

作者头像 李华
网站建设 2026/4/8 13:27:39

探索基于STM32F407VET6的三相PFC技术之旅

基于stm32f407Vet6的三相PFC参考利用dq变换,PID控制,spwm等,知识点非常多,是您学习技术的好帮手,成语完整,并有详细技术文档说明,程序工程可编译,并带有中文注释。在电力电子领域&am…

作者头像 李华
网站建设 2026/4/16 10:53:13

一文搞懂CNN - LSTM - Attention回归预测:新手友好实战

CNN-LSTM-Attention回归,基于卷积神经网络(CNN)-长短期记忆神经网络(LSTM)结合注意力机制(Attention)的数据回归预测,多变量输入单输入,可以更换为时序预测,多变量/单变量都有 LSTM可根据需要更换为BILSTM,GRU 程序已经调试好&…

作者头像 李华
网站建设 2026/4/13 20:54:54

SPSS——判别分析——“一般判别分析”

更多免费教程和软件 :​ 判别分析 【判别分析的概念和目的】 判别分析是一种对观察对象进行分类的统计学方法,它与聚类分析不同,它在分析之前就非常明确观察对象分为几个类别,该分析方法的目的就是从现有已知类别的观察对象中建立一个判别函数来,然后再用该判别函数去判…

作者头像 李华
网站建设 2026/4/16 11:05:28

Agent 结构(LLM + Tool + Executor)

day29:理解Agent 结构(LLM Tool Executor) 一、Agent定义 简单介绍 Agent 能“思考 → 决策 → 调用工具 → 再思考”的 LLM 程序 公式化一点就是: Agent LLM Tools Executor它和「问 → 答」最大的区别是: LLM …

作者头像 李华
网站建设 2026/4/16 11:01:21

Tarjan全家桶系列--割点

割点定义 在无向图G(V,E)中,如果一个节点u满足:删除u以及与u相关联的所有边后,图的连通分量数量增加,则称u为割点。 核心思想 Tarjan算法仍然基于深度优先搜索(DFS),利用两个关键数组&#xff1…

作者头像 李华