嘉义县网站建设_网站建设公司_交互流畅度_seo优化
2026/1/5 19:09:36 网站建设 项目流程

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

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


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

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

  • 10G级文件传输:分片上传(5MB/片),断点续传(localStorage+MySQL双存储进度,关浏览器/重启电脑不丢)。
  • 文件夹层级保留:递归遍历文件树(前端生成相对路径),后端按/文件夹/子文件路径存储(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,无额外费用。
  • 本地/云存储适配:支持本地文件系统+ECS+OSS(私有云/公有云),代码动态配置存储路径。

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

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

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

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

import { ref, onMounted } from 'vue'; import SparkMD5 from 'spark-md5'; import CryptoJS from 'crypto-js'; import axios from 'axios'; const fileInput = ref(null); const uploadTasks = ref([]); const chunkSize = 5 * 1024 * 1024; // 5MB分片(兼容IE8内存) let aesKey = ''; // AES密钥(从后端动态获取) let currentTaskId = ''; // 上传下一个分片(递归) const uploadNextChunk = (task) => { if (task.chunkIndex >= task.totalChunks) { task.progress = 100; task.status = 'success'; task.statusText = '上传成功'; localStorage.removeItem(`upload_${task.taskId}`); ElMessage.success(`${task.fileName} 上传完成!`); return; } const start = task.chunkIndex * chunkSize; const end = Math.min(start + chunkSize, task.totalSize); const chunk = task.file.slice(start, end); // IE8支持File.slice // 3. 读取分片内容并加密(原生JS) const reader = new FileReader(); reader.onload = (function(chunk, task) { return function(e) { const chunkContent = e.target.result; // AES加密(兼容IE8的crypto-js) const encryptedChunk = CryptoJS.AES.encrypt( CryptoJS.lib.WordArray.create(chunkContent), aesKey, { mode: CryptoJS.mode.ECB, padding: CryptoJS.pad.Pkcs7 } ).toString(); // 4. 构造FormData(兼容IE8) const 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. 调用后端上传接口(SpringBoot) axios.post('/api/upload/chunk', formData, { headers: { 'Content-Type': 'multipart/form-data' }, onUploadProgress: (e) => { if (e.lengthComputable) { const 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 = '上传中...'; uploadNextChunk(task); }).catch((err) => { task.status = 'failed'; task.statusText = `上传失败:${err.response?.data?.msg || '网络错误'}`; }); }; })(chunk, task); reader.readAsArrayBuffer(chunk); }; onMounted(() => { initAesKey(); checkResumeTasks(); });

三、后端核心代码(SpringBoot + MySQL + OSS)

1. 分片上传服务(核心逻辑)

// com.example.uploader.service.UploadService.java@Service@Slf4jpublicclassUploadService{@Value("${upload.chunk.size:5242880}")// 5MB分片privatelongchunkSize;@Value("${oss.access.key:your-access-key}")privateStringossAccessKey;@Value("${oss.secret.key:your-secret-key}")privateStringossSecretKey;@Value("${oss.bucket.name:your-bucket}")privateStringossBucket;@AutowiredprivateUploadProgressMapperprogressMapper;// MyBatis Mapper(MySQL)// 上传分片(支持断点续传)publicvoiduploadChunk(UploadChunkDTOchunkDTO,MultipartFilechunk)throwsIOException{// 1. 校验分片有效性(文件指纹+签名)StringfileHash=calculateFileHash(chunkDTO.getFileId(),chunk.getSize());if(!validateChunkSignature(chunkDTO,fileHash)){thrownewSecurityException("分片签名验证失败");}// 2. 解密分片(AES-256)byte[]decryptedChunk=aesDecrypt(chunk.getBytes(),chunkDTO.getUploadToken());// 3. 保存分片到OSS(支持公有云/私有云)StringossPath=getOssPath(chunkDTO.getFilePath(),chunkDTO.getChunkIndex());ossClient.putObject(ossBucket,ossPath,newByteArrayInputStream(decryptedChunk));// 4. 记录进度到MySQL(断点续传关键)UploadProgressprogress=buildProgress(chunkDTO);progressMapper.insertOrUpdate(progress);// MyBatis动态SQL(兼容MySQL)}}

2. 数据库动态配置(MySQL)

-- 创建上传进度表(记录分片上传状态)CREATETABLEIFNOTEXISTSupload_progress(idINTUNSIGNEDAUTO_INCREMENTPRIMARYKEY,task_idVARCHAR(255)NOTNULLCOMMENT'任务ID',file_idVARCHAR(255)NOTNULLCOMMENT'文件唯一ID',chunk_indexINTNOTNULLCOMMENT'当前分片索引',total_chunksINTNOTNULLCOMMENT'总分片数',file_pathVARCHAR(1000)NOTNULLCOMMENT'文件存储路径',uploaded_sizeBIGINTNOTNULLCOMMENT'已上传大小',statusVARCHAR(50)NOTNULLDEFAULT'pending'COMMENT'状态(pending/resuming/uploading/failed/success)',create_timeTIMESTAMPDEFAULTCURRENT_TIMESTAMP,update_timeTIMESTAMPDEFAULTCURRENT_TIMESTAMPONUPDATECURRENT_TIMESTAMP,UNIQUEKEYuk_task_file(task_id,file_id,chunk_index)-- 防止重复记录)ENGINE=InnoDBDEFAULTCHARSET=utf8mb4;

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

1. IE8兼容性调试(必看!)

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

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

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

3. OSS上传调试(阿里云)

  • 权限问题:OSS Bucket需配置公共读/私有读写权限(测试用公共读即可)。
  • 跨域问题:在OSS控制台配置CORS规则,允许前端域名访问(*通配符测试)。

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

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

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

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


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

SQL示例

创建数据库

配置数据库连接

自动下载maven依赖

启动项目

启动成功

访问及测试

默认页面接口定义

在浏览器中访问

数据表中的数据

效果预览

文件上传

文件刷新续传

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

文件夹上传

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

示例下载

下载完整示例

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

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

立即咨询