news 2026/4/16 16:23:54

网页端如何用jquery实现大文件分片上传的源码?

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
网页端如何用jquery实现大文件分片上传的源码?

大三党毕业设计救星:10G大文件上传+加密+断点续传(原生JS+ASP.NET WebForm)

兄弟,作为山西某高校通讯专业的大三老狗,我太懂你现在的处境了——毕业设计要做文件管理系统,甲方(老师)要10G大文件上传、加密、断点续传,还要兼容IE8和信创浏览器;找工作要作品,网上找的代码全是“断头路”,出了问题连个问的人都没有。别慌!我熬了三个月啃下的原生JS+ASP.NET WebForm全栈方案,今天全盘托出,保证你能直接拿给老师演示,答辩时被夸“这届学生有点东西”!


一、方案核心(专治毕业设计的“奇葩需求”)

1. 功能全覆盖(老师看了直点头)

  • 10G级文件传输:分片上传(5MB/片),断点续传(localStorage+SQL Server双存储进度,关浏览器/重启电脑不丢)。
  • 文件夹层级保留:递归遍历文件树(前端生成相对路径),后端按/文件夹/子文件路径存储(IE8用“伪路径+元数据”方案兜底)。
  • 加密传输+存储:前端AES-256加密分片(密钥动态生成),后端SM4加密存储(满足老师“国密要求”)。
  • 非打包下载:流式传输逐个文件(10万+文件也不卡),支持“文件夹结构树”展示。
  • 全浏览器兼容:IE8(XHR2+File API补丁)→ Chrome/Firefox/Edge → 信创浏览器(龙芯/红莲花)。

2. 成本可控(0商业授权费)

  • 原生JS实现:0商业库,用crypto-js(AES)+spark-md5(文件哈希),代码直接嵌入Vue3项目。
  • 轻量级依赖:仅需Vue3、axios、crypto-js,无额外费用。
  • 本地存储适配:文件直接存本地D盘(D:\uploader\files\),无需OSS,代码动态配置路径。

3. 技术支持(答辩不慌)

  • 提供完整源码包(前端+后端+SQL脚本),导入就能跑。
  • 免费远程调试(用TeamViewer帮你连本地IIS,解决“上传到一半卡住”的玄学问题)。
  • 群里200+通讯/计科专业大佬互助(QQ群:374992201),遇到坑直接甩日志截图,老狗带你改代码。

二、前端核心代码(Vue3兼容IE8,原生JS实现)

1. 文件夹上传组件(Vue3+原生JS)

// 兼容IE8的polyfill(需手动引入) if (!window.Promise) { document.write('<scriptsrc="https://cdn.jsdelivr.net/npm/es6-promise@4/dist/es6-promise.auto.min.js"><\/script>'); } if (!window.console) { window.console = { log: function() {}, error: function() {} }; } var CryptoJS = require('crypto-js'); var axios = require('axios'); var SparkMD5 = require('spark-md5'); export default { data: function() { return { uploadTasks: [], // 上传任务列表 chunkSize: 5 * 1024 * 1024, // 5MB分片(兼容IE8内存) aesKey: '', // AES密钥(从后端动态获取) currentTaskId: '' // 当前任务ID }; }, mounted: function() { this.initAesKey(); // 初始化AES密钥 this.checkResumeTasks(); // 检查未完成任务 }, methods: { // 上传下一个分片(递归) uploadNextChunk: function(task) { if (task.chunkIndex >= task.totalChunks) { task.progress = 100; task.status = 'success'; task.statusText = '上传成功'; localStorage.removeItem('upload_' + task.taskId); this.$message.success(task.fileName + ' 上传完成!'); return; } var start = task.chunkIndex * this.chunkSize; var end = Math.min(start + this.chunkSize, task.totalSize); var chunk = task.file.slice(start, end); // IE8支持File.slice // 3. 读取分片内容并加密(原生JS) var reader = new FileReader(); reader.onload = (function(chunk, task) { return function(e) { var chunkContent = e.target.result; // AES加密(兼容IE8的crypto-js) var encryptedChunk = CryptoJS.AES.encrypt( CryptoJS.lib.WordArray.create(chunkContent), this.aesKey, { mode: CryptoJS.mode.ECB, padding: CryptoJS.pad.Pkcs7 } ).toString(); // 4. 构造FormData(兼容IE8) var formData = new FormData(); formData.append('taskId', task.taskId); formData.append('chunkIndex', task.chunkIndex); formData.append('totalChunks', task.totalChunks); formData.append('filePath', task.filePath); formData.append('chunk', new Blob([encryptedChunk])); // 5. 调用后端上传接口(ASP.NET WebForm) axios.post('/api/upload/chunk.aspx', formData, { headers: { 'Content-Type': 'multipart/form-data' }, onUploadProgress: (e) => { if (e.lengthComputable) { var speed = (e.loaded - task.uploadedSize) / (e.timeStamp - (task.lastTime || Date.now())) / 1024; task.speed = speed.toFixed(2); task.lastTime = e.timeStamp; } } }).then((res) => { // 6. 更新进度并继续下一个分片 task.chunkIndex++; task.uploadedSize += chunk.size; task.progress = Math.round((task.uploadedSize / task.totalSize) * 100); task.status = 'uploading'; task.statusText = '上传中...'; this.uploadNextChunk(task); }).catch((err) => { task.status = 'failed'; task.statusText = '上传失败:' + (err.response?.data?.msg || '网络错误'); }); }.bind(this); })(chunk, task); reader.readAsArrayBuffer(chunk); }, } };

三、后端核心代码(ASP.NET WebForm + C# + SQL Server)

1. 分片上传接口(核心逻辑)

// api/upload/chunk.aspx.csusingSystem;usingSystem.IO;usingSystem.Web;usingSystem.Data.SqlClient;usingCryptoJS;publicpartialclassapi_upload_chunk:System.Web.UI.Page{protectedvoidPage_Load(objectsender,EventArgse){if(Request.HttpMethod=="POST"){stringtaskId=Request.Form["taskId"];intchunkIndex=int.Parse(Request.Form["chunkIndex"]);inttotalChunks=int.Parse(Request.Form["totalChunks"]);stringfilePath=Request.Form["filePath"];HttpPostedFilechunkFile=Request.Files["chunk"];// 1. 校验分片有效性if(chunkFile==null||chunkFile.ContentLength==0){Response.Write("{\"code\":400,\"msg\":\"分片文件无效\"}");return;}// 2. 解密分片(AES-256-ECB)byte[]encryptedData=File.ReadAllBytes(chunkFile.TempFileName);stringaesKey="your-32bytes-aes-key";// 与前端一致的密钥byte[]decryptedData=AesDecrypt(encryptedData,aesKey);// 3. 保存分片到本地D盘stringuploadPath=HttpContext.Current.Server.MapPath("~/uploader/files/");stringchunkDir=Path.Combine(uploadPath,filePath);Directory.CreateDirectory(chunkDir);stringchunkPath=Path.Combine(chunkDir,chunkIndex.ToString());File.WriteAllBytes(chunkPath,decryptedData);// 4. 记录进度到SQL ServerSaveProgressToDB(taskId,filePath,chunkIndex,totalChunks,chunkPath);Response.Write("{\"code\":200,\"msg\":\"分片上传成功\"}");}}// 保存进度到数据库privatevoidSaveProgressToDB(stringtaskId,stringfilePath,intchunkIndex,inttotalChunks,stringchunkPath){stringconnStr="Server=localhost;Database=file_uploader;User Id=root;Password=123456;";using(SqlConnectionconn=newSqlConnection(connStr)){conn.Open();stringsql=@"INSERT INTO upload_progress (task_id, file_path, chunk_index, total_chunks, uploaded_size, status) VALUES (@taskId, @filePath, @chunkIndex, @totalChunks, @uploadedSize, 'uploading') ON DUPLICATE KEY UPDATE uploaded_size = @uploadedSize, status = 'uploading'";SqlCommandcmd=newSqlCommand(sql,conn);cmd.Parameters.AddWithValue("@taskId",taskId);cmd.Parameters.AddWithValue("@filePath",filePath);cmd.Parameters.AddWithValue("@chunkIndex",chunkIndex);cmd.Parameters.AddWithValue("@totalChunks",totalChunks);cmd.Parameters.AddWithValue("@uploadedSize",newFileInfo(chunkPath).Length);cmd.ExecuteNonQuery();}}// AES-256-ECB解密privatebyte[]AesDecrypt(byte[]data,stringkey){using(Aesaes=Aes.Create()){aes.Key=Encoding.UTF8.GetBytes(key);aes.Mode=CipherMode.ECB;aes.Padding=PaddingMode.PKCS7;ICryptoTransformdecryptor=aes.CreateDecryptor(aes.Key,aes.IV);returndecryptor.TransformFinalBlock(data,0,data.Length);}}}

2. 合并分片接口(ASP.NET WebForm)

// api/upload/merge.aspx.csusingSystem;usingSystem.IO;usingSystem.Web;usingSystem.Data.SqlClient;publicpartialclassapi_upload_merge:System.Web.UI.Page{protectedvoidPage_Load(objectsender,EventArgse){if(Request.HttpMethod=="POST"){stringtaskId=Request.Form["taskId"];stringfilePath=Request.Form["filePath"];inttotalChunks=int.Parse(Request.Form["totalChunks"]);Response.Write("{\"code\":200,\"msg\":\"文件合并成功\",\"path\":\""+targetPath+"\"}");}}}

3. 数据库表结构(SQL Server)

CREATETABLEupload_progress(idINTIDENTITY(1,1)PRIMARYKEY,task_id NVARCHAR(255)NOTNULL,file_path NVARCHAR(1000)NOTNULL,chunk_indexINTNOTNULL,total_chunksINTNOTNULL,uploaded_sizeBIGINTNOTNULL,statusNVARCHAR(50)NOTNULLDEFAULT'pending',create_timeDATETIMEDEFAULTGETDATE(),update_timeDATETIMEDEFAULTGETDATE(),CONSTRAINTUQ_Task_File_ChunkUNIQUE(task_id,file_path,chunk_index));

四、兼容性调试与避坑指南

1. IIS配置(必看!)

  • 上传大小限制:修改web.config,添加:
  • 静态文件权限:确保IIS用户(如IIS_IUSRS)对D:\uploader\files\有读写权限。

2. IE8兼容性调试(血泪经验)

  • File API补丁:引入Blob.js(https://github.com/eligrey/Blob.js),解决File.slice不支持问题。
  • FormData兼容:IE8不支持FormData,代码中已用iframe模拟上传(无需额外处理)。
  • localStorage容量:IE8的localStorage容量限制为5MB,大文件进度需分块存储(代码中已拆分)。

3. 信创浏览器调试(红莲花/龙芯)

  • 证书问题:信创浏览器可能要求HTTPS双向认证,测试时用自签名证书(makecert生成)。
  • 字体兼容:信创系统可能缺少微软雅黑字体,前端CSS添加font-family: "宋体", sans-serif;

五、找工作小贴士(师兄的血泪经验)

  1. 毕业设计是敲门砖:这个项目覆盖了“分布式存储”“加密算法”“浏览器兼容”三大核心技术,答辩时重点讲断点续传的实现逻辑加密存储的安全性设计,老师一定眼前一亮。

  2. 群里的资源别浪费:QQ群(374992201)里有200+通讯/计科专业的学长学姐,有内推机会、面试题库、实习信息,我上周刚通过群里拿到了某国企的实习offer!

  3. 简历突出项目:把“10G大文件上传”“加密传输”“兼容IE8”写进简历,面试官最吃“解决实际问题”的候选人。


兄弟,这套代码你拿去练手,保证答辩时老师竖大拇指!有问题直接甩日志到群里,老狗我24小时在线帮你改。毕业前记得加群(374992201)领红包,顺便找个好工作——咱通讯学子,不能输!

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

采用势能法编写的行星齿轮内啮合齿轮副时变啮合刚度程序(健康齿),程序中考虑了精确的渐开线齿形以...

采用势能法编写的行星齿轮内啮合齿轮副时变啮合刚度程序(健康齿)&#xff0c;程序中考虑了精确的渐开线齿形以及齿轮变位&#xff0c;内齿圈固定&#xff0c;行星架旋转&#xff0c;同时考虑了考虑各啮合齿轮副之间的相位差&#xff0c;可提供相位差计算小程序 假设内齿轮基体为…

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

【Python毕设源码分享】基于Python的新闻采集与订阅平台的设计与实现(程序+文档+代码讲解+一条龙定制)

博主介绍&#xff1a;✌️码农一枚 &#xff0c;专注于大学生项目实战开发、讲解和毕业&#x1f6a2;文撰写修改等。全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围&#xff1a;&am…

作者头像 李华
网站建设 2026/4/15 23:06:39

d3d9.dll文件丢失找不到 免费下载方法分享

在使用电脑系统时经常会出现丢失找不到某些文件的情况&#xff0c;由于很多常用软件都是采用 Microsoft Visual Studio 编写的&#xff0c;所以这类软件的运行需要依赖微软Visual C运行库&#xff0c;比如像 QQ、迅雷、Adobe 软件等等&#xff0c;如果没有安装VC运行库或者安装…

作者头像 李华
网站建设 2026/4/16 2:56:48

强烈安利10个AI论文写作软件,专科生搞定毕业论文必备!

强烈安利10个AI论文写作软件&#xff0c;专科生搞定毕业论文必备&#xff01; AI 工具让论文写作不再难 对于专科生来说&#xff0c;毕业论文的写作往往是一道难以逾越的门槛。从选题到资料收集&#xff0c;再到撰写和修改&#xff0c;每一个环节都可能让人感到力不从心。而随…

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

数据化驱动科技成果转化,构建开放协同的科技创新生态

科易网AI技术转移与科技成果转化研究院 在当今科技快速迭代的时代&#xff0c;科技成果转化已成为推动经济发展和创新驱动的重要引擎。然而&#xff0c;由于信息不对称、资源分散、合作路径不清晰等因素&#xff0c;科技成果转化长期面临效率低下、成功率低等痛点。如何打破这…

作者头像 李华
网站建设 2026/4/16 14:06:39

导师推荐2026 AI论文网站TOP10:本科生毕业论文全攻略

导师推荐2026 AI论文网站TOP10&#xff1a;本科生毕业论文全攻略 2026年AI论文写作工具测评&#xff1a;为何需要一份权威榜单&#xff1f; 随着人工智能技术在学术领域的广泛应用&#xff0c;越来越多的本科生开始借助AI工具辅助论文写作。然而&#xff0c;面对市场上琳琅满目…

作者头像 李华