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

前端与JAVA后端分块上传的协同实现经验

《Java老哥的100元奇迹》

各位同行好啊!我是一名来自甘肃的Java老程序员,最近接了个"史诗级"外包项目——预算高达100元人民币!这价格连兰州牛肉面都吃不了几碗,但客户要的功能怕是马化腾来了都得摇头…

一、需求分析:100元买航母

客户要求清单:

  • 20G文件上传:我家宽带一个月流量都没20G
  • IE9兼容:“业务机器不能扔”——这话听着就像"我爷爷的算盘还能用"
  • 文件夹结构保持:1000个分类文件层级不能乱,这需求比我家的族谱还复杂
  • 断点续传:关了浏览器进度不能丢,这功能应该叫"程序员寿命续传"
  • 加密存储:SM4+AES双加密,我银行卡密码都没这么安全
  • 7×24小时支持:100元买我命?

二、技术选型:用爱发电

前端方案(Vue3 + 原生JS地狱)

// 文件夹上传核心代码(IE9特别版)functionhandleFolderUpload(files){constpromise=newPromise((resolve,reject)=>{if(navigator.userAgent.indexOf('MSIE 9')>-1){alert('IE9用户请先升级到Windows 10');reject('建议客户扔掉这台电脑');}else{// 实际处理代码resolve('上传成功(可能)');}});returnpromise;}

后端方案(SpringBoot魔改版)

// 文件分片接收接口@PostMapping("/upload")publicResponseEntityupload(@RequestParam("file")MultipartFilefile,@RequestParam("chunkNumber")intchunkNumber,@RequestParam("totalChunks")inttotalChunks,HttpServletRequestrequest){// 预算只够写伪代码if(file.getSize()>20_000_000_000L){returnResponseEntity.badRequest().body("加钱!");}try{// 假装这里有很多代码returnResponseEntity.ok("第"+chunkNumber+"块上传成功");}catch(Exceptione){returnResponseEntity.status(500).body("建议预算加两个零");}}

三、加密实现(玄学版)

// SM4加密(伪代码)publicclassSM4Utils{publicstaticStringencrypt(Stringinput){// 真实实现需要300行代码// 但100元预算只配用Base64returnBase64.getEncoder().encodeToString(input.getBytes());}}

四、文件夹结构保持黑科技

// 数据库设计(精简版)@EntitypublicclassFileNode{@IdprivateStringid;privateStringpath;// 如 "/root/folder/file.txt"privatebooleanisDirectory;// 其他字段...}

五、断点续传实现思路

  1. 前端计算文件hash作为唯一标识
  2. 后端记录已上传分片信息
  3. 每次上传前先查询上传进度
// 断点记录表@EntitypublicclassUploadProgress{@IdprivateStringfileHash;privateStringfileName;privateStringfilePath;privateinttotalChunks;privateStringuploadedChunks;// 如 "1,3,5-8"}

六、现实建议

  1. 价格谈判:建议把单位从人民币改成比特币
  2. IE9兼容:直接告诉客户加钱换电脑更划算
  3. 20G文件:先确认客户服务器硬盘有多大
  4. 时间估算:100元预算≈1小时工作量(含做梦时间)

七、QQ群真相揭秘

“加群送红包”:我加了群只收到空气红包
“项目提成50%”:最后发现是项目亏损的50%
“互联网大厂待遇”:大厂起码给交五险一金啊!

八、生存指南

  1. 需求评审:把不合理需求都标成"加钱项"
  2. 技术方案:尽量用现成轮子(虽然预算买不起)
  3. 合同签订:写明"IE9支持需要额外付费"
  4. 心态调整:准备好改行送外卖的Plan B

完整解决方案(做梦版)

如果真的不得不做:

  1. 前端用Vue3+WebUploader魔改
  2. 后端用SpringBoot+分片上传
  3. 数据库记录文件树结构
  4. 加密用Bouncy Castle库

但老哥们,100元连代码自动补全会员都买不起啊!要不咱们组团去送外卖吧?听说一个月能挣好几个100元呢!(手动狗头)

最后的呐喊:那个QQ群广告才是重点吧!老哥你其实是想拉人头对不对?(看破不说破)

导入项目

导入到Eclipse:点南查看教程
导入到IDEA:点击查看教程
springboot统一配置:点击查看教程

工程

NOSQL

NOSQL示例不需要任何配置,可以直接访问测试

创建数据表

选择对应的数据表脚本,这里以SQL为例

修改数据库连接信息

访问页面进行测试

文件存储路径

up6/upload/年/月/日/guid/filename

效果预览

文件上传

文件刷新续传

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

文件夹上传

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

下载示例

点击下载完整示例

http://www.jsqmd.com/news/165582/

相关文章:

  • 湖北省仙桃市自建房设计靠谱机构评测排行榜:5星平台优势及客户评价 - 苏木2025
  • 本章节我们将讨论如何在 React 中使用表单
  • 湖南省岳阳市自建房设计公司排行榜出炉!权威评测 + 真实案例,建房选对不踩坑 - 苏木2025
  • 湖南省张家界市设计公司权威评测排行榜:6大维度打分,5星企业全解析 - 苏木2025
  • containerd怎么离线安装
  • 堆垛机控制系统 FC12货叉清零功能块实现
  • 【开题答辩全过程】以 基于安卓的停车位管理系统与设计为例,包含答辩的问题和答案
  • 湖南省衡阳市自建房设计公司/机构权威测评推荐排行榜 - 苏木2025
  • 堆垛机控制系统步FC12功能块赋值每一步目标脉冲
  • WebUploader分块上传在JSP中的加密传输步骤
  • 湖北省随州市自建房设计公司排行榜出炉!权威评测 + 真实案例,建房选对不踩坑 - 苏木2025
  • 湖南省邵阳市自建房设计公司评测排行榜:6 家主流企业实地测评,哪家更靠谱? - 苏木2025
  • 基于spark的西南天气数据的分析与应用_plbe9x5o
  • 基于Spark的南昌房价数据分析系统的设计与实现_45i0b357
  • 节能智能高效:2025年优质网带炉厂家推荐榜单 - 品牌推荐大师1
  • 数据安全与数据民主化可以兼得?Data Agent 如何实现精细化权限管控?
  • 基于大数据技术的医疗数据分析与研究
  • 儿童去屑止痒洗发水哪个好?2025年权威实验室封神榜:这五款品牌止痒去屑双效合一 - 资讯焦点
  • 【开题答辩全过程】以 基于Web酒店管理的设计与实现为例,包含答辩的问题和答案
  • 湖北省恩施市自建房设计公司哪家强?2025最新评测排行榜 + 5 星企业推荐 - 苏木2025
  • 湖北省黄冈市自建房设计公司/机构权威测评推荐排行榜 - 苏木2025
  • springboot基于JAVA的二手书籍交易系统的设计与实现
  • springboot基于Java的高校超市管理系统设计与实现
  • 【CMake】`install()` 命令详解
  • Nature Medicine | 新疗法通过免疫重置攻克难治性狼疮,这篇文章的Python代码是单细胞+空间转录组学分析的典范
  • 湖北省荆州市市自建房设计公司哪家强?2026年最新权威靠谱测评榜单抢先看 - 苏木2025
  • 绝佳教材 | 这篇模式生物(果蝇)多组学文章,涉及RNA-seq,ChIP-seq和ATAC-seq,代码全公开,值得好好学习
  • 为什么未来 3 年,AI 系统如果“不会拒绝”,就一定上不了线?
  • 2025-2026湖北省咸宁市自建房设计公司权威测评排行榜:核心推荐机构深度解析 - 苏木2025
  • debian 与 ubuntu 之 - CD-ROM in source