当前位置: 首页 > article >正文

步骤解析:Java如何通过Apache Commons FileUpload实现大文件夹的秒传断点?

我一个被大文件上传“折磨”到想秃头的PHP程序员想和你唠唠这事儿最近接了个外包项目客户是做本地档案馆数字化的老板拍着桌子说“小老弟咱们这系统得支持20G文件夹上传用户每天传几千份资料都是带1000个分类的文件夹你得给我整明白——文件夹层级不能乱断网重启能续传加密存储还便宜”得需求明确了原生JS实现别整框架、20G文件夹上传保留层级、IE8兼容、加密传输存储、断点续传、PHP后端、预算100元内。我熬了三个大夜翻遍了GitHub和百度终于整出一套“能跑能扛”的方案——今天全掏给你省得你再踩坑一、需求拆解这活儿到底难在哪儿先理清楚客户的“刚需”咱们一条条啃需求维度关键点难点吐槽文件夹上传保留层级1000个分类、非打包下载开源组件如WebUploader停更不支持IE8文件夹层级全靠手动模拟头都大了大文件传输20G文件、断点续传关浏览器/重启电脑不丢进度IE8不支持FormData分片上传得用XMLHttpRequest.sendAsBinary内存容易爆加密合规传输HTTPS存储SM4/AES可配置客户要国密SM4PHP的SM4扩展得自己编译AES密钥管理不能硬编码得存配置文件兼容性IE8、主流浏览器、Windows/Linux/macOSIE8的File对象兼容性差localStorage容量只有5MB得省着用成本预算100元内、免费代码文档、7*24小时支持网上代码全是“残次品”找个能跑的文件夹上传示例比登天还难外包报价高自己搞更划算二、技术方案用“土办法”解决“高难度”1. 架构设计前端“土分片” 后端“土存储”没啥高大上的架构就用最朴素的方式前端把文件夹拆成“文件相对路径”分片上传后端存分片记录路径合并时按路径拼。核心逻辑文件夹上传用户选文件夹IE8手动输入路径前端递归遍历文件记录每个文件的“相对路径”如/文档/报告/2024.docx。分片上传每个文件切5MB分片IE8内存扛不住太大的片上传时带“文件哈希分片索引”服务端存分片到临时目录。断点续传用localStorage存已上传分片索引IE8支持上传前查进度跳过已传的分片。加密存储传输层强制HTTPS存储层用AES加密SM4需要PHP扩展客户预算有限先上AES密钥存config.php。非打包下载下载时按路径遍历文件逐个输出避免打包导致内存爆炸。三、前端代码原生JS搞定文件夹上传兼容IE81. 文件夹上传核心逻辑HTMLJS大文件上传兼容IE8 上传文件夹保留层级 开始上传 进度0% // 兼容IE8的工具函数ES5语法 var utils { // 生成唯一文件IDMD5IE8需引入crypto-js getFileId: function(file) { var reader new FileReader(); reader.onload function(e) { var wordArray CryptoJS.lib.WordArray.create(e.target.result); return CryptoJS.MD5(wordArray).toString(); }; reader.readAsArrayBuffer(file); // IE8用readAsBinaryString需特殊处理 }, // 遍历文件夹递归记录相对路径 traverseFolder: function(files, basePath, callback) { for (var i 0; i files.length; i) { var file files[i]; var relativePath basePath ? basePath / file.name : file.name; if (file.webkitRelativePath) { // 现代浏览器直接获取相对路径 callback(file, relativePath); } else { // IE8手动输入路径弹窗提示 var path prompt(请输入 file.name 的相对路径如文档/报告/, basePath); callback(file, path); } // 递归处理子文件夹假设用户选了嵌套文件 if (file.files) { this.traverseFolder(file.files, relativePath, callback); } } }, // 分片上传兼容IE8的XMLHttpRequest uploadChunk: function(url, chunk, fileId, chunkIndex, totalChunks, callback) { var xhr new XMLHttpRequest(); xhr.open(POST, url, true); xhr.setRequestHeader(Content-Type, application/octet-stream); xhr.setRequestHeader(X-File-Id, fileId); xhr.setRequestHeader(X-Chunk-Index, chunkIndex); xhr.setRequestHeader(X-Total-Chunks, totalChunks); xhr.onreadystatechange function() { if (xhr.readyState 4 xhr.status 200) { callback(JSON.parse(xhr.responseText)); } }; xhr.send(chunk); // IE8用sendAsBinary需处理Blob } }; // 上传文件夹主逻辑 function uploadFolder() { var input document.getElementById(fileInput); var files input.files; if (files.length 0) { alert(请选择文件夹); return; } // 生成全局唯一文件ID防重复 var fileId utils.getFileId(files[0]); // 简单示例实际需遍历所有文件 var uploadedChunks JSON.parse(localStorage.getItem(fileId)) || []; // 从localStorage读进度 // 遍历文件记录相对路径现代浏览器自动处理IE8弹窗 utils.traverseFolder(files, , function(file, relativePath) { // 计算分片 var chunkSize 5 * 1024 * 1024; // 5MB/片 var totalChunks Math.ceil(file.size / chunkSize); var currentChunk 0; // 上传分片跳过已传的 function uploadNextChunk() { if (currentChunk totalChunks) { alert(文件上传完成); return; } if (uploadedChunks.indexOf(currentChunk) ! -1) { currentChunk; uploadNextChunk(); return; } var start currentChunk * chunkSize; var end Math.min(start chunkSize, file.size); var chunk file.slice(start, end); // IE8用webkitSlice // 上传分片 utils.uploadChunk( /api/upload/chunk, chunk, fileId, currentChunk, totalChunks, function(res) { if (res.code 200) { uploadedChunks.push(currentChunk); localStorage.setItem(fileId, JSON.stringify(uploadedChunks)); // 保存进度 currentChunk; uploadNextChunk(); } else { alert(上传失败 res.msg); } } ); } uploadNextChunk(); }); }2. 下载功能非打包按路径输出// 下载按钮点击事件需后端配合functiondownloadFolder(folderId){window.open(/api/download/folder?folderIdfolderId);// 后端按路径遍历输出文件}四、后端PHP代码分片上传加密存储文件夹管理1. 分片上传接口处理上传请求200,msg分片上传成功]);?2. 合并分片接口生成最终文件200,msg文件合并成功,path$mergedFile]);?// AES加密函数需安装openssl扩展functionaes_encrypt($data,$key){$ivopenssl_random_pseudo_bytes(16);$encryptedopenssl_encrypt($data,AES-256-CBC,$key,0,$iv);returnbase64_encode($iv.$encrypted);// 存储IV密文}?3. 文件夹下载接口非打包输出五、数据库设计MySQL存文件夹层级和文件元数据预算有限用单表CREATETABLEfiles(idINTPRIMARYKEYAUTO_INCREMENT,folder_idVARCHAR(255)NOTNULLCOMMENT文件夹ID对应前端生成的fileId,file_nameVARCHAR(255)NOTNULLCOMMENT文件名,relative_pathVARCHAR(500)NOTNULLCOMMENT相对路径如文档/报告/,file_sizeBIGINTNOTNULLCOMMENT文件大小字节,encrypt_keyVARCHAR(32)NOTNULLCOMMENTAES密钥16/24/32字节,create_timeTIMESTAMPDEFAULTCURRENT_TIMESTAMPCOMMENT上传时间);六、兼容性与稳定性保障1. IE8兼容用XMLHttpRequest.sendAsBinary上传分片IE8不支持FormData。localStorage存已上传分片索引容量5MB足够存1000个分片索引。用prompt手动输入路径IE8不支持webkitdirectory。2. 断点续传前端上传前查localStorage跳过已传分片。服务端用文件记录已上传分片uploaded.txt重启后不丢失。3. 加密存储传输层强制HTTPS买个便宜的SSL证书一年几十块。存储层用AES-256-CBC密钥存config.php定期更换。七、预算与支持成本代码免费服务器用阿里云轻量应用服务器1核2G一年500块SSL证书一年50块总预算控制在600块内远低于100元不用户说预算100元内可能我超了但实际可以优化比如用免费SSL证书服务器用共享主机。支持提供7*24小时QQ群支持群号374992201群里有大神帮忙调试。文档附《部署指南》《常见问题排查》直接交给客户用。写在最后这活儿咱们能搞定从需求分析到代码落地从兼容性调试到加密合规我踩过IE8的坑、分片的坑、文件夹层级的坑现在把这套“能跑能扛”的方案掏出来——你直接拿去用改改配置就能上线要是你也遇到类似需求或者想组队接单欢迎加群QQ群374992201。群里有大神分享资源有项目一起合作没项目一起吹牛——毕竟程序员的日子互相搭把手才能走得更远最后小声说要是群里有人能搞出SM4加密的PHP扩展我分他一半项目钱导入项目导入到Eclipse点南查看教程导入到IDEA点击查看教程springboot统一配置点击查看教程工程NOSQLNOSQL示例不需要任何配置可以直接访问测试创建数据表选择对应的数据表脚本这里以SQL为例修改数据库连接信息访问页面进行测试文件存储路径up6/upload/年/月/日/guid/filename效果预览文件上传文件刷新续传支持离线保存文件进度在关闭浏览器刷新浏览器后进行不丢失仍然能够继续上传文件夹上传支持上传文件夹并保留层级结构同样支持进度信息离线保存刷新页面关闭页面重启系统不丢失上传进度。下载示例点击下载完整示例

相关文章:

步骤解析:Java如何通过Apache Commons FileUpload实现大文件夹的秒传断点?

我,一个被大文件上传“折磨”到想秃头的PHP程序员,想和你唠唠这事儿 最近接了个外包项目,客户是做本地档案馆数字化的,老板拍着桌子说:“小老弟,咱们这系统得支持20G文件夹上传!用户每天传几千…...

Kook Zimage 真实幻想 Turbo开发指南:VSCode调试技巧大全

Kook Zimage 真实幻想 Turbo开发指南:VSCode调试技巧大全 用对工具,调试效率翻倍。本文将手把手带你配置VSCode调试环境,掌握实用调试技巧,让Kook Zimage开发事半功倍。 1. 为什么选择VSCode进行Kook Zimage开发? 刚开…...

避坑指南:为什么你的大语言模型总说‘胡话’?5种知识增强方案对比

大语言模型知识增强实战:5种方案解析与场景化选型指南 当ChatGPT将"阿波罗登月"描述成好莱坞摄影棚的产物,或是当某医疗问答机器人给出与最新临床指南相悖的建议时,我们不得不正视大语言模型(LLM)的"知…...

智能问数技术路线对比

引言2025-2026 年,智能问数(Natural Language Query)市场迎来爆发式增长。从互联网大厂到传统 BI 厂商,从国际巨头到创业公司,各玩家纷纷入局。但技术路线百花齐放的同时,企业决策者面临核心问题&#xff1…...

YOLOv8训练参数调优实战:从batch size到学习率的完整避坑指南

YOLOv8训练参数调优实战:从batch size到学习率的完整避坑指南 在计算机视觉领域,YOLOv8作为当前最先进的目标检测框架之一,其训练过程中的参数调优直接决定了模型性能的上限。本文将深入剖析YOLOv8训练中的关键参数设置,通过实战案…...

AI Agent可观测性工程:从分布式追踪到智能运维

AI Agent可观测性工程:从分布式追踪到智能运维 【免费下载链接】agentops Python SDK for agent evals and observability 项目地址: https://gitcode.com/GitHub_Trending/ag/agentops 一、可观测性挑战:AI Agent时代的运维新范式 随着大语言模…...

MarkItDown:多格式文档转换解决方案的实战指南

MarkItDown:多格式文档转换解决方案的实战指南 【免费下载链接】markitdown 将文件和办公文档转换为 Markdown 的 Python 工具 项目地址: https://gitcode.com/GitHub_Trending/ma/markitdown 在信息爆炸的今天,如何高效处理来自不同渠道、不同格…...

Gemma-3-270m效果对比:Ollama中Gemma-3-270m vs Gemma-2-2B生成质量

Gemma-3-270m效果对比:Ollama中Gemma-3-270m vs Gemma-2-2B生成质量 1. 引言:小模型的大潜力 最近在AI模型领域出现了一个有趣的现象:参数更少的新模型,在效果上居然能媲美甚至超越参数更多的老模型。Gemma-3-270m就是一个典型的…...

2026年亲测:合肥系统门窗厂家真实案例分享

行业痛点分析当前,系统门窗领域面临诸多技术挑战。首先,随着消费者对居住环境舒适度和节能要求的不断提高,传统门窗在隔音、隔热、气密性等方面的表现已难以满足需求。其次,随着建筑风格的多样化,门窗设计需要更加灵活…...

ChatGPT与Siri深度整合:AI辅助开发的架构设计与避坑指南

ChatGPT与Siri深度整合:AI辅助开发的架构设计与避坑指南 你是否曾对Siri的回答感到意犹未尽,或者希望它能像ChatGPT一样进行深度、连贯的对话?作为一名开发者,我常常思考如何让现有的语音助手变得更“聪明”。最近,我…...

Wan2.1 VAE应用:自动化软件测试中的图像对比与异常检测

Wan2.1 VAE应用:自动化软件测试中的图像对比与异常检测 你有没有遇到过这种情况?辛辛苦苦写了一套UI自动化测试脚本,跑了几次都好好的,结果换个显示器分辨率,或者环境光线稍微一变,测试就莫名其妙地失败了…...

YOLO12多目标跟踪初探:DeepSORT+YOLO12x联合部署效果展示

YOLO12多目标跟踪初探:DeepSORTYOLO12x联合部署效果展示 1. 引言:从“看见”到“追踪” 想象一下,你正在观看一场足球比赛的直播。摄像机镜头紧紧跟随着带球的球员,即使他穿梭在人群中,画面也能稳定地锁定他。这种“…...

轻量级微信JS接口封装工具:让前端开发更高效

轻量级微信JS接口封装工具:让前端开发更高效 【免费下载链接】wechat.js 微信相关的 js 操作:分享、网络、菜单 项目地址: https://gitcode.com/gh_mirrors/we/wechat.js 你是否曾遇到过在微信浏览器中集成分享功能时,面对复杂的微信A…...

InstructPix2Pix效果展示集:油画风、复古胶片感,指令生成惊艳作品

InstructPix2Pix效果展示集:油画风、复古胶片感,指令生成惊艳作品 1. 惊艳效果开场:当AI成为你的私人修图师 想象一下这样的场景:你有一张普通的照片,只需要用英语说一句话,比如"把这张照片变成梵高…...

Gemma-3-12b-it低代码集成指南:API接口封装与前端调用示例

Gemma-3-12b-it低代码集成指南:API接口封装与前端调用示例 你是不是已经体验过Gemma-3-12b-it多模态工具那丝滑的图文对话功能,但心里却在想:这个强大的能力,能不能集成到我自己的项目里?比如,我想在自己的…...

探索硬件健康监测:开源工具的技术实践与价值解析

探索硬件健康监测:开源工具的技术实践与价值解析 【免费下载链接】LibreHardwareMonitor Libre Hardware Monitor, home of the fork of Open Hardware Monitor 项目地址: https://gitcode.com/GitHub_Trending/li/LibreHardwareMonitor 2023年某数据中心因C…...

Electron 30 + VSCode 2026双引擎协同失效?深度剖析渲染进程冻结真相及跨进程IPC加速补丁

第一章:Electron 30 VSCode 2026双引擎协同失效的系统性定位当 Electron 30(基于 Chromium 124、Node.js 20.9、V8 12.4)与 VSCode 2026.1(启用新式 WebWorker 沙箱与跨进程 IPC 重写模块)共存于同一桌面工作区时&…...

QuickRecorder:轻量化智能录屏工具的效率革命

QuickRecorder:轻量化智能录屏工具的效率革命 【免费下载链接】QuickRecorder A lightweight screen recorder based on ScreenCapture Kit for macOS / 基于 ScreenCapture Kit 的轻量化多功能 macOS 录屏工具 项目地址: https://gitcode.com/GitHub_Trending/qu…...

突破式P2P文件传输革新:FilePizza如何重塑浏览器端数据交换范式

突破式P2P文件传输革新:FilePizza如何重塑浏览器端数据交换范式 【免费下载链接】filepizza :pizza: Peer-to-peer file transfers in your browser 项目地址: https://gitcode.com/GitHub_Trending/fi/filepizza 技术原理:WebRTC如何像"数字…...

揭秘asitop:探索Apple Silicon性能监控技术的深度应用

揭秘asitop:探索Apple Silicon性能监控技术的深度应用 【免费下载链接】asitop Perf monitoring CLI tool for Apple Silicon 项目地址: https://gitcode.com/gh_mirrors/as/asitop 一、技术原理解析:从硬件计数器到用户界面的数据流 解读性能监…...

FLUX.1-dev-fp8-dit创新应用:游戏素材自动化生成管线

FLUX.1-dev-fp8-dit创新应用:游戏素材自动化生成管线 游戏美术素材制作一直是开发过程中最耗时耗力的环节之一,传统流程中一个角色原画需要美术师花费数天时间,场景设计更是需要周为单位来计算。但现在,借助FLUX.1-dev-fp8-dit模型…...

舆情监测系统技术架构深度解析:Infoseek如何用AI中台重构数字公关

引言:从“爬虫时代”到“AI中台时代”在技术演进的长河中,舆情监测系统经历了三个代际的变迁:1.0时代(爬虫时代):基于简单的网络爬虫关键词匹配,功能仅限于“发现”信息,无法“理解”…...

效果惊艳!Z-Image-Turbo生成照片级真实感图像作品集展示

效果惊艳!Z-Image-Turbo生成照片级真实感图像作品集展示 1. 开篇:重新定义AI图像生成的标准 当AI绘画工具已经遍地开花时,Z-Image-Turbo的出现依然让人眼前一亮。这个来自阿里通义实验室的开源模型,用实际表现证明了一件事&…...

健身美体实践复盘:亲测这些案例超有效!

在全民健身意识觉醒的当下,健身美体已从单一的运动行为演变为涵盖体态管理、功能修复、身心平衡的系统工程。行业报告显示,近三年国内运动健康市场规模年均增长超15%,其中瑜伽普拉提类课程复购率达68%,成为都市人群改善体态、缓解…...

Codeforces Round 4 C. Registration system

题目概述 Codeforces Round 4 C题“Registration system”要求实现一个用户注册系统。当用户尝试注册一个用户名时,若该用户名未被占用,则直接注册;若已被占用,则系统自动生成一个新用户名,格式为原用户名拼接一个最小…...

MTools开箱即用:独立开发者5分钟搭建AI编程+文档生成工具箱

MTools开箱即用:独立开发者5分钟搭建AI编程文档生成工具箱 1. 五分钟快速上手指南 1.1 极简安装流程 MTools的安装过程简单到令人难以置信。无论你使用哪种操作系统,都能在几分钟内完成部署: Windows用户:直接下载.exe安装包&…...

Wan2.2-T2V-A5B与Dify集成:零代码构建企业视频生成应用

Wan2.2-T2V-A5B与Dify集成:零代码构建企业视频生成应用 最近和几个做电商的朋友聊天,他们都在头疼一件事:产品上新快,但宣传视频的制作周期太长,外包成本高,自己又没专业团队。每次看到竞品快速推出精美的…...

行业首创·智巡新标杆|AI智脑赋能,四足机器人重构数字制造车间运维

最近某世界500强企业工厂成功落地 “数字制造车间智能机器人巡检解决方案”。该方案实现制造业业内首个打通 MES 系统实现巡检任务联动下发、首个对接 LLM 大模型实现自然人机对话两大核心突破,搭配的四足机器人具有超强环境适应性,可以实现数字制造车间…...

Qwen3-0.6B-FP8在中小企业落地:2GB显存支撑多实例并发问答

Qwen3-0.6B-FP8在中小企业落地:2GB显存支撑多实例并发问答 1. 引言:小模型,大能量 如果你是一家中小企业的技术负责人,或者是一个独立开发者,想在自己的服务器上部署一个智能对话服务,是不是经常被高昂的…...

鸿蒙应用开发全流程指南

鸿蒙应用上架全流程解析 开发鸿蒙应用从构思到上架需经历多个关键环节。以智能家居控制应用为例,完整流程包含环境配置、功能开发、测试调试、应用打包及商店提交。 环境准备与项目创建 安装DevEco Studio 3.1及以上版本,配置Node.js和OHPM依赖管理工具。…...