news 2026/3/29 4:26:03

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/3/25 14:21:14

71 CompletableFuture组合与异步编排

CompletableFuture组合与异步编排 本文深入剖析CompletableFuture的组合操作,详解allOf、anyOf、thenCombine等核心API,结合生产实践讲解异常处理和资源清理,掌握企业级异步编程最佳实践。 1 为什么需要CompletableFuture组合 业务场景分析 在企业级系统开发中,经常遇到需要同…

作者头像 李华
网站建设 2026/3/22 5:50:15

南朝:刘宋王朝兴衰脉络

刘宋&#xff08;420 年 —479 年&#xff09;是南朝首个政权&#xff0c;由刘裕代东晋建立&#xff0c;享国 59 年&#xff0c;历 4 代 8 帝&#xff0c;是南朝疆域最广、国力最强的王朝&#xff0c;其兴衰贯穿 “奠基强盛 — 治世巅峰 — 内乱崩解 — 权臣代立” 的完整脉络&…

作者头像 李华
网站建设 2026/3/15 22:59:21

不懂技术怎么分辨正版?新手必看

晚上好&#xff0c;我是晓衡&#xff01;今天事情比较多&#xff0c;我就简单快速回复下一位老铁的问题&#xff01;昨天后台有个老铁给我留言&#xff0c;说他&#xff1a;“晓衡哥&#xff0c;我是小白不懂代码&#xff0c;要怎么区别正版盗版呢&#xff1f;”不讲高深的技术…

作者头像 李华
网站建设 2026/3/20 8:44:37

PHP网页中如何处理大视频文件的分块上传分享?

大文件上传系统开发指南&#xff08;PHP原生JS&#xff09; 项目概述 兄弟&#xff0c;你这需求可真够硬的&#xff01;20G文件上传、文件夹层级保留、全浏览器兼容、加密传输存储、断点续传…这活儿不轻松啊&#xff01;不过既然你找到我了&#xff0c;咱们就一起啃下这块硬…

作者头像 李华
网站建设 2026/3/25 10:57:36

农业物联网平台TinyMCE6粘贴气象图表出现数据点错位?

各位道友且听好&#xff01;本杭电大三码农最近在搞TinyMCE编辑器"超级缝合怪"升级&#xff0c;目标让Word文档在编辑器里实现"量子纠缠式"还原——连师哥的秃头曲线图都能完美保留&#xff01;&#xff08;狗头保命&#xff09; 一、技术栈全家桶&#xf…

作者头像 李华