news 2026/4/27 20:05:58

PHP在国企项目中如何处理视频大附件的切片分享?

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
PHP在国企项目中如何处理视频大附件的切片分享?

老哥的大文件上传历险记

各位同行兄弟好啊!我是辽宁的一名"资深"(其实就是年纪大了) Java 程序员,最近接了个外包项目,要求可真是把我这老腰给闪了!

需求分析:这活儿比东北虎还猛

客户要的文件上传功能,那叫一个全面啊:

  • 20G大文件传输(我硬盘才500G啊)
  • 文件夹上传保留层级(1000个分类?这是要上天啊)
  • 加密传输存储(SM4、AES全要)
  • 断点续传(关浏览器、重启电脑都不能丢进度)
  • 兼容IE9(这年头还有人用IE9?)
  • 预算100元以内(我早餐都不止这个价啊!)

技术选型:老哥我太难了

前端要用原生JS实现,不能用现成框架。后端是SpringBoot+Vue3,这组合倒是挺时髦。但是!要兼容IE9?这不是让我用5G网络给大哥大打电话吗?

部分代码实现:能跑就行

前端部分 (原生JS)

// 文件上传核心逻辑 - 兼容IE9的魔改版functionuploadFile(file,relativePath=''){returnnewPromise((resolve,reject)=>{// 为IE9准备的XHR对象constxhr=window.XMLHttpRequest?newXMLHttpRequest():newActiveXObject("Microsoft.XMLHTTP");// 分片上传逻辑constchunkSize=5*1024*1024;// 5MBletoffset=0;// 读取文件分片constreadChunk=()=>{constchunk=file.slice(offset,offset+chunkSize);// 加密分片 (伪代码)constencryptedChunk=encryptChunk(chunk,'SM4');constformData=newFormData();formData.append('file',encryptedChunk);formData.append('fileName',file.name);formData.append('relativePath',relativePath);formData.append('totalSize',file.size);formData.append('chunkSize',chunkSize);formData.append('offset',offset);xhr.open('POST','/api/upload',true);xhr.setRequestHeader('X-Requested-With','XMLHttpRequest');xhr.onload=function(){if(xhr.status===200){offset+=chunkSize;if(offset<file.size){readChunk();// 继续上传下一分片}else{resolve();// 上传完成}}else{reject(newError('上传失败'));}};xhr.send(formData);};readChunk();});}// 文件夹上传 - 递归处理functionuploadFolder(entries,relativePath=''){returnPromise.all(Array.from(entries).map(entry=>{returnnewPromise((resolve)=>{if(entry.isFile){entry.file(file=>{uploadFile(file,relativePath).then(resolve);});}elseif(entry.isDirectory){constdirReader=entry.createReader();dirReader.readEntries(entries=>{uploadFolder(entries,`${relativePath}/${entry.name}`).then(resolve);});}});}));}

后端部分 (SpringBoot)

@RestController@RequestMapping("/api")publicclassFileUploadController{@PostMapping("/upload")publicResponseEntityuploadFile(@RequestParam("file")MultipartFilefile,@RequestParam("fileName")StringfileName,@RequestParam(value="relativePath",defaultValue="")StringrelativePath,@RequestParam("totalSize")longtotalSize,@RequestParam("chunkSize")intchunkSize,@RequestParam("offset")longoffset){try{// 解密文件分片 (伪代码)byte[]decryptedData=decryptChunk(file.getBytes(),"SM4");// 构建目标路径,保留文件夹结构PathtargetPath=Paths.get("uploads",relativePath,fileName);Files.createDirectories(targetPath.getParent());// 断点续传处理if(offset==0){Files.write(targetPath,decryptedData);}else{Files.write(targetPath,decryptedData,StandardOpenOption.APPEND);}// 检查是否上传完成longuploadedSize=offset+chunkSize;if(uploadedSize>=totalSize){// 文件上传完成后的处理returnResponseEntity.ok().body("上传完成");}else{returnResponseEntity.ok().body("分片上传成功");}}catch(Exceptione){returnResponseEntity.status(500).body("上传失败: "+e.getMessage());}}// 文件夹下载接口@GetMapping("/downloadFolder")publicvoiddownloadFolder(@RequestParamStringfolderPath,HttpServletResponseresponse)throwsIOException{PathsourcePath=Paths.get("uploads",folderPath);if(!Files.exists(sourcePath)){response.sendError(404,"文件夹不存在");return;}response.setContentType("application/octet-stream");response.setHeader("Content-Disposition","attachment; filename=\""+URLEncoder.encode(sourcePath.getFileName().toString(),"UTF-8")+"\"");// 非打包下载,逐个文件传输try(OutputStreamout=response.getOutputStream()){Files.walk(sourcePath).filter(Files::isRegularFile).forEach(file->{try{// 保留相对路径StringrelativePath=sourcePath.relativize(file).toString();// 写入文件信息头out.write(("FILE:"+relativePath+":"+Files.size(file)+"\n").getBytes());// 写入文件内容Files.copy(file,out);out.write("\n\n".getBytes());// 文件分隔符}catch(IOExceptione){thrownewUncheckedIOException(e);}});}}}

老哥的心里话

兄弟们啊,100块钱预算要搞这么复杂的系统,这不是难为我这"资深"程序员吗?还要7×24小时技术支持,这得加多少个鸡腿啊!

不过话说回来,咱们程序员不就是喜欢挑战吗?虽然这需求比东北的冬天还冷,但谁让咱们是"代码界的抗寒战士"呢!

友情提示:完整实现这个系统需要解决很多细节问题,比如:

  1. 大文件分片上传的稳定性
  2. IE9兼容性的各种坑
  3. 文件夹层级结构的准确保持
  4. 加密性能优化
  5. 断点续传的状态管理

如果真要做成产品级质量,建议:

  1. 增加预算(至少加两个零)
  2. 考虑使用成熟的文件存储服务
  3. 放弃IE9支持(真心的!)

欢迎加入我们的QQ群(374992201)一起讨论,虽然红包可能没有99元那么大,但技术交流绝对真诚!

安装环境

PHP:7.2.14

调整块大小

NOSQL

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

SQL

创建数据库

您可以直接复制脚本进行创建

配置数据库连接

安装依赖

访问页面进行测试

数据表中的数据

效果预览

文件上传

文件刷新续传

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

文件夹上传

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

免费下载示例

点击下载完整示例

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

国产化系统中PHP如何实现视频大文件的分块分享?

【一个武汉大四狗的"大文件上传"自救实录&#xff1a;从"PHP&#xff1f;那不是用来写留言板的吗&#xff1f;“到"哥的上传系统能扛住整个光谷的流量&#xff01;”】 "同学&#xff0c;你简历上写’熟悉PHP开发’&#xff0c;那能说说怎么用PHP实现…

作者头像 李华
网站建设 2026/4/23 13:38:37

Qt学习第一个程序:Hello,World

本文将以Qt 5/6&#xff08;通用步骤&#xff0c;两者无核心差异&#xff09;、Qt Creator开发工具为例&#xff0c;完成经典的Hello&#xff0c;World程序&#xff0c;包含纯代码编写和UI拖拽两种方式&#xff0c;步骤详细且适合零基础入门&#xff0c;确保每一步都能落地执行…

作者头像 李华
网站建设 2026/4/23 17:23:40

互联网大厂Java求职面试实战:多技术栈与业务场景深度解析

互联网大厂Java求职面试实战&#xff1a;多技术栈与业务场景深度解析 本文通过一个企业协同与SaaS场景的面试故事&#xff0c;真实展现互联网大厂Java求职者谢飞机与严肃面试官的问答过程&#xff0c;涵盖Java SE、Spring Boot、微服务、数据库、缓存、消息队列、安全框架、AI等…

作者头像 李华
网站建设 2026/4/20 13:43:05

从 .env 到动态配置:前端工程的一次升级

点击上方 程序员成长指北&#xff0c;关注公众号 回复1&#xff0c;加入高级Node交流群 前言 很多前端和 Node.js 项目&#xff0c;配置管理几乎都是从环境变量开始的&#xff1a;.env、process.env、再配合一次部署。但当你需要临时关掉一个功能、调整接口限流、做灰度发布时&…

作者头像 李华
网站建设 2026/4/23 8:13:19

军工装备管理系统TinyMCE4导入PDF图纸出现字体缺失怎么办?

项目需求技术评估与实施方案 一、需求背景分析 作为北京某国企项目负责人&#xff0c;我们当前面临在企业网站后台管理系统中集成Word粘贴、文档导入和微信公众号内容处理功能的迫切需求。该需求源于政府项目对文档处理能力提升的要求&#xff0c;同时需要满足信创国产化环境…

作者头像 李华
网站建设 2026/4/20 19:35:14

告别杂乱!NAS 装个 Sun-Panel+cpolar,数据管理居然能这么省心

Sun-Panel 是一款主打可视化整合的私有云管理工具&#xff0c;核心功能是把 NAS、服务器、常用工具的访问入口收拢到统一面板&#xff0c;支持多账号权限隔离&#xff0c;还能自定义界面样式&#xff0c;适配 Windows、macOS、Linux 等多系统&#xff0c;甚至树莓派也能流畅运行…

作者头像 李华