news 2026/5/5 3:54:22

vue2中如何实现内网大文件的跨平台上传?

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
vue2中如何实现内网大文件的跨平台上传?

一个准毕业码农的"史诗级"文件管理系统开发日记

各位码友大家好,我就是那个被10G大文件折磨得死去活来的山西大三狗!😭

血泪开发史

“老师,我这个文件管理系统能传10G文件!” —— 这话说出来我自己都不信,毕竟我的笔记本硬盘总共才256G…

前端技术选型心路历程

“原生JS+Vue3?这不是前后矛盾吗?” —— 我的导师看到我的技术栈时露出了关爱智障的眼神。但我要证明这是可以实现的!

// 大文件分片上传核心代码片段(纯手工打造,童叟无欺)constMAX_CHUNK_SIZE=5*1024*1024;// 5MB一片,别问为什么,问就是IE8会哭functionsplitFile(file){letchunks=[];letstart=0;while(start<file.size){letend=Math.min(start+MAX_CHUNK_SIZE,file.size);chunks.push({chunk:file.slice(start,end),index:chunks.length,total:Math.ceil(file.size/MAX_CHUNK_SIZE),fileName:file.name,fileSize:file.size});start=end;}returnchunks;}// 断点续传黑科技(localStorage+IndexedDB双备份)functionsaveProgress(fileMd5,chunkIndex){try{localStorage.setItem(`upload_${fileMd5}`,chunkIndex);// 这里应该还有IndexedDB的代码,但是...我还没学会...}catch(e){console.log("您的存储空间已爆炸💥");}}

浏览器兼容性炼狱

“IE8?Win7?国产浏览器?” —— 当我看到需求文档时,我以为回到了2010年…

// 检测浏览器是否支持File API(给IE8老爷爷准备的轮椅)functioncheckBrowserSupport(){if(!window.File||!window.FileReader||!window.FileList||!window.Blob){alert('您的浏览器太老了,建议升级到IE9...等等,IE9也很老啊!');returnfalse;}returntrue;}// 文件夹上传的魔术代码(其实也没那么神奇)functionhandleFolderUpload(event){letfiles=event.target.files;letentries=[];// 这个webkitRelativePath是文件夹上传的关键!for(leti=0;i<files.length;i++){letfile=files[i];if(file.webkitRelativePath){entries.push({path:file.webkitRelativePath,file:file});}}returnentries;}

开发路上那些坑

  1. 断点续传的离线存储:我天真地以为localStorage就够用了,直到遇到了10G文件…现在正在恶补IndexedDB

  2. 文件夹层级保留:"webkitRelativePath"这个属性名字看起来就像是个临时工写的,但它确实是唯一能用的方案

  3. 加密传输:本来是准备用AES的,后来发现IE8不支持,现在正在研究如何用RSA+DES组合拳

求带飞环节

“有没有师傅愿意收留我这个迷途的羔羊?后端代码还是一片空白啊!Python?Java?PHP?我都可以学!” 😇

前端完整实现思路(伪代码版)

classMegaUploader{constructor(){this.chunks=[];this.uploaded=0;this.fileMd5='';this.resumeData=this.loadResumeData();}// 大文件MD5计算(分片计算避免卡死)calculateFileMd5(file){returnnewPromise((resolve)=>{// 这里应该有很复杂的计算逻辑...setTimeout(()=>resolve("mock_md5_"+file.name),500);});}// 断点续传数据加载loadResumeData(){// 先从localStorage尝试// 失败后尝试IndexedDB// 再失败...那就从头开始吧return{};}// 真正的上传逻辑asyncupload(file){this.fileMd5=awaitthis.calculateFileMd5(file);this.chunks=splitFile(file);// 检查服务器哪些分片已经上传letuploadedChunks=awaitcheckServerProgress(this.fileMd5);// 只上传未完成的部分for(leti=0;i<this.chunks.length;i++){if(!uploadedChunks.includes(i)){awaitthis.uploadChunk(this.chunks[i]);saveProgress(this.fileMd5,i);}}// 所有分片完成,通知服务器合并awaitnotifyServerMerge(this.fileMd5,file.name);}// 上传单个分片uploadChunk(chunk){returnnewPromise((resolve,reject)=>{letformData=newFormData();formData.append('file',chunk.chunk);formData.append('chunkIndex',chunk.index);formData.append('totalChunks',chunk.total);formData.append('fileMd5',this.fileMd5);// 这里应该有加密逻辑...fetch('/upload',{method:'POST',body:formData}).then(response=>{if(response.ok){this.uploaded++;resolve();}else{reject('上传失败');}});});}}

致未来的雇主大大

“虽然我现在连个完整的后端都写不出来,但我前端已经能画出漂亮的进度条了!” 💪

PS:那个QQ群是真的,红包也是真的(虽然最大那个99元的红包可能已经被我领走了…)

将组件复制到项目中

示例中已经包含此目录

引入组件

配置接口地址

接口地址分别对应:文件初始化,文件数据上传,文件进度,文件上传完毕,文件删除,文件夹初始化,文件夹删除,文件列表
参考:http://www.ncmem.com/doc/view.aspx?id=e1f49f3e1d4742e19135e00bd41fa3de

处理事件

启动测试

启动成功

效果

数据库

效果预览

文件上传

文件刷新续传

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

文件夹上传

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

下载示例

点击下载完整示例

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

芯片制造企业文档系统怎样处理Origin数据图到网页的粘贴?

今天早上&#xff0c;又有技术爱好者通过公开渠道找到我的联系方式并加我微信&#xff0c;表示对我们正在探索的Word文档导入编辑器技术感兴趣&#xff0c;想了解具体方案。其实&#xff0c;我的联系方式之前已在多个平台公开&#xff0c;但仍有不少朋友反馈难以找到&#xff0…

作者头像 李华
网站建设 2026/4/26 4:48:35

分布式电源接入对配电网的影响——基于Matlab程序的潮流计算与分析

分布式电源接入对配电网的影响&#xff08;matlab程序&#xff09; 分布式电源的接入使得配电系统从放射状无源网络变为分布有中小型电源的有源网络。 带来了使单向流动的电流方向具有了不确定性等等问题&#xff0c;使得配电系统的控制和管理变得更加复杂。 但同时&#xff0c…

作者头像 李华
网站建设 2026/5/1 10:24:58

多用户小程序源码系统,核心功能齐全,助力您快速部署创业

温馨提示&#xff1a;文末有资源获取方式 市场上通用的SaaS模板往往无法完全契合每家洗衣店独特的业务模式和运营构想。对于追求自主控制、期望功能独具特色的商家或开发者而言&#xff0c;一套开源、可深度定制的源码才是真正的宝藏。本文将以列表形式&#xff0c;解析一款高度…

作者头像 李华
网站建设 2026/4/26 17:16:59

Java 面向对象进阶三

第一章 接口1.1 概述我们已经学完了抽象类&#xff0c;抽象类中可以用抽象方法&#xff0c;也可以有普通方法&#xff0c;构造方法&#xff0c;成员变量等。那么什么是接口呢&#xff1f;接口是更加彻底的抽象&#xff0c;JDK7之前&#xff0c;包括JDK7&#xff0c;接口中全部是…

作者头像 李华
网站建设 2026/5/2 20:27:50

智能守护:视频安全监测系统的演进与未来

在城市天际线与街巷角落&#xff0c;数以亿计的摄像头正悄然编织一张无形的安全网络。然而&#xff0c;当监控画面从“被动记录”迈向“主动预警”&#xff0c;视频安全监测系统已不再是简单的录像工具&#xff0c;而是融合人工智能、边缘计算与大数据的智能守护者。一、超越“…

作者头像 李华
网站建设 2026/5/1 15:36:27

全网最全9个降AI率网站推荐!千笔·降AIGC助手帮你精准降AIGC

AI降重工具如何精准降低AIGC率&#xff1f; 在当前学术写作和论文提交中&#xff0c;AI生成内容的痕迹越来越明显&#xff0c;很多学生和研究人员都面临“论文被查出高AIGC率”的困扰。为了确保论文通过检测系统&#xff0c;越来越多的人开始依赖专业的AI降重工具。这些工具不仅…

作者头像 李华