台中市网站建设_网站建设公司_会员系统_seo优化
2026/1/20 12:16:23 网站建设 项目流程

大三党毕业设计救星: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)领红包,顺便找个好工作——咱通讯学子,不能输!

需要专业的网站建设服务?

联系我们获取免费的网站建设咨询和方案报价,让我们帮助您实现业务目标

立即咨询