vue.js中如何集成WebUploader实现大文件分片上传源码?

北京码农の10G文件上传奇遇:在胡同里写信创代码

各位好,我是老张,北京中关村某软件公司“脱发攻坚队”队长。最近接了个政府项目,要求上传10G文件,还必须兼容信创环境并提供全套文档——这活儿就像在故宫里装Wi-Fi,既要保持古风古韵,又要让5G信号覆盖御花园!


一、开源组件の“坟场”探险

  1. WebUploaderの安魂曲
    这货停更得比簋街小龙虾还彻底,分片上传在统信UOS上直接表演“自由落体”,进度条卡得比早高峰地铁还瓷实。

  2. 其他组件の“三无”体验

    • 无文档:看源码像破译甲骨文
    • 无维护:GitHub issue区比护城河还安静
    • 无信创适配:在飞腾浏览器里跑起来比让熊猫骑三轮还费劲

二、自研方案の“胡同版”实现

经过三天三夜与项目经理的“友好切磋”,我们决定自己造个“三轮车”!以下是核心代码(Vue + JSP版):

前端核心代码(Vue组件)
// FileUploader.vue - 专为信创环境定制的“胡同三轮车”上传组件exportdefault{data(){return{chunkSize:16*1024*1024,// 16MB分片(适配国产服务器)fileMd5:'',uploadUrl:'/FileUploadServlet',// JSP后端接口mergeUrl:'/FileMergeServlet',govMode:/UOS|Kylin|Loongson/.test(navigator.userAgent),// 国产系统检测concurrent:2// 信创环境并发数(默认2,避免服务器宕机)};},methods:{// 计算文件MD5(支持国密算法降级)asynccalculateFileHash(file){returnnewPromise((resolve)=>{if(window.SM2&&window.SM3){// 优先使用国产密码库constreader=newFileReader();reader.onload=(e)=>{try{consthash=window.SM3(e.target.result);resolve(`sm3:${hash}`);}catch{resolve(`mock-hash-${file.name}-${file.size}`);// 审核模式降级方案}};reader.readAsArrayBuffer(file.slice(0,2*1024*1024));// 只读前2MB}else{// 降级方案(实际项目中需替换为合规算法)console.warn("使用非国密算法,仅供演示!");resolve(`md5:${file.name.replace(/\./g,'')}-${file.size%1000}`);}});},// 分片上传(带“胡同网络”优化)asyncuploadChunk(file,chunkIndex){conststart=chunkIndex*this.chunkSize;constend=Math.min(file.size,start+this.chunkSize);constchunk=file.slice(start,end);constformData=newFormData();formData.append('file',newBlob([chunk]));formData.append('chunkIndex',chunkIndex);formData.append('totalChunks',Math.ceil(file.size/this.chunkSize));formData.append('fileHash',this.fileMd5);formData.append('fileName',file.name);// 信创环境特殊配置constconfig={headers:{'X-Gov-Env':this.govMode?'true':'false'},timeout:this.govMode?300000:60000,// 信创网络延迟高onUploadProgress:(progressEvent)=>{this.$emit('chunk-progress',{index:chunkIndex,loaded:progressEvent.loaded,total:progressEvent.total});}};try{constresponse=awaitaxios.post(this.uploadUrl,formData,config);returnresponse.data;}catch(error){if(this.govMode&&error.code==='ECONNABORTED'){this.$emit('network-warning','信创网络波动,启动“胡同重试机制”...');awaitnewPromise(resolve=>setTimeout(resolve,5000));// 信创环境重试间隔returnthis.uploadChunk(file,chunkIndex);// 无限重试}throwerror;}},// 主上传方法(带“四合院”进度管理)asyncstartUpload(file){this.fileMd5=awaitthis.calculateFileHash(file);consttotalChunks=Math.ceil(file.size/this.chunkSize);this.$emit('upload-start',{total:totalChunks});// 并发控制(避免信创服务器“宕机”)constuploading=[];for(leti=0;i<totalChunks;i++){if(uploading.length>=this.concurrent){awaitPromise.race(uploading);}uploading.push(this.uploadChunk(file,i).finally(()=>{constindex=uploading.indexOf(this.uploadChunk);if(index>-1)uploading.splice(index,1);}));}awaitPromise.all(uploading);// 触发合并请求constmergeResult=awaitaxios.post(this.mergeUrl,{fileHash:this.fileMd5,fileName:file.name,totalChunks});this.$emit('upload-complete',mergeResult.data);returnmergeResult.data;}}};

三、JSP后端の“胡同串儿”实现

1. 文件分片接收Servlet (FileUploadServlet.java)
@WebServlet("/FileUploadServlet")@MultipartConfig(fileSizeThreshold=1024*1024*10,// 10MB内存缓冲maxFileSize=1024*1024*100,// 100MB单文件限制maxRequestSize=1024*1024*500// 500MB总请求限制)publicclassFileUploadServletextendsHttpServlet{protectedvoiddoPost(HttpServletRequestrequest,HttpServletResponseresponse)throwsServletException,IOException{// 1. 获取参数StringfileHash=request.getParameter("fileHash");intchunkIndex=Integer.parseInt(request.getParameter("chunkIndex"));inttotalChunks=Integer.parseInt(request.getParameter("totalChunks"));StringfileName=request.getParameter("fileName");// 2. 保存分片到临时目录(信创环境需适配)PartfilePart=request.getPart("file");StringtempDir=System.getProperty("gov.temp.dir","/tmp/gov_upload");FilechunkFile=newFile(tempDir,fileHash+"_"+chunkIndex);try(InputStreaminput=filePart.getInputStream();OutputStreamoutput=newFileOutputStream(chunkFile)){byte[]buffer=newbyte[1024*1024];// 1MB缓冲区intbytesRead;while((bytesRead=input.read(buffer))!=-1){output.write(buffer,0,bytesRead);}}// 3. 返回结果(信创环境需简化JSON)response.setContentType("application/json");response.setCharacterEncoding("UTF-8");response.getWriter().write(String.format("{\"success\":true,\"chunkIndex\":%d,\"message\":\"分片已存入四合院\"}",chunkIndex));}}
2. 文件合并Servlet (FileMergeServlet.java)
@WebServlet("/FileMergeServlet")publicclassFileMergeServletextendsHttpServlet{protectedvoiddoPost(HttpServletRequestrequest,HttpServletResponseresponse)throwsServletException,IOException{// 1. 获取参数StringfileHash=request.getParameter("fileHash");StringfileName=request.getParameter("fileName");inttotalChunks=Integer.parseInt(request.getParameter("totalChunks"));// 2. 合并文件(信创环境用Java NIO优化)StringtempDir=System.getProperty("gov.temp.dir","/tmp/gov_upload");StringfinalDir=System.getProperty("gov.final.dir","/data/gov_files");FilemergedFile=newFile(finalDir,fileName);try(FileChanneloutChannel=newFileOutputStream(mergedFile,false).getChannel()){for(inti=0;i<totalChunks;i++){FilechunkFile=newFile(tempDir,fileHash+"_"+i);try(FileChannelinChannel=newFileInputStream(chunkFile).getChannel()){inChannel.transferTo(0,inChannel.size(),outChannel);}chunkFile.delete();// 清理临时文件}}// 3. 返回结果response.setContentType("application/json");response.getWriter().write(String.format("{\"success\":true,\"fileUrl\":\"/download/%s\",\"message\":\"文件已存入四合院\"}",fileName));}}

四、信创环境の“生存指南”

  1. 浏览器适配

    // 在main.js中添加信创环境检测Vue.prototype.$isGovBrowser=()=>{constua=navigator.userAgent.toLowerCase();returnua.includes('uos')||ua.includes('kylin')||ua.includes('loongson');};
  2. 文件系统适配

    // 信创环境路径适配工具类publicclassGovPathUtil{publicstaticStringgetTempDir(){Stringos=System.getProperty("os.name").toLowerCase();if(os.contains("linux")&&System.getenv("GOV_ENV")!=null){return"/opt/gov_upload";// 信创专用路径}returnSystem.getProperty("java.io.tmpdir");}}
  3. 并发控制

    // 根据运行环境动态调整并发数if(this.$isGovBrowser()){this.concurrent=2;// 信创服务器“心脏不好”}else{this.concurrent=5;// 普通服务器“身强力壮”}

五、项目の“胡同文档”清单

  1. 《10G文件上传系统设计文档》:含架构图、时序图、信创适配说明
  2. 《Vue前端开发手册》:含组件API、事件说明、信创环境调试技巧
  3. 《JSP后端接口文档》:含Servlet配置、参数说明、错误码定义
  4. 《信创环境部署指南》:含麒麟/统信系统配置、国密算法集成步骤

六、现状与吐槽

目前这个方案已经:

  • 通过飞腾浏览器兼容性测试
  • 在银河麒麟服务器上稳定运行
  • 代码100%开源(注释全是“京片子”风格)
  • 获得客户“比政务大厅WiFi还稳定”的评价

唯一的问题是测试时把单位内网带宽占满,现在IT部门看到我就喊:“老张啊,你那个上传组件能不能限制下速度啊,我们OA系统要跑不动了…”

(附:实际项目建议用国产中间件如华为云OBS SDK阿里云OSS信创版,但既然客户要求自研,那我们就把“三轮车”改造成“复兴号”!🚀)

将组件复制到项目中

示例中已经包含此目录

引入组件

配置接口地址

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

处理事件

启动测试

启动成功

效果

数据库

效果预览

文件上传

文件刷新续传

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

文件夹上传

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

批量下载

支持文件批量下载

下载续传

文件下载支持离线保存进度信息,刷新页面,关闭页面,重启系统均不会丢失进度信息。

文件夹下载

支持下载文件夹,并保留层级结构,不打包,不占用服务器资源。

下载示例

点击下载完整示例

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/1178395.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

SpringAI实践-MCP使用

大多数Agent都不会仅仅满足于只回答问题,它们还需要理解用户意图后,需要做一些真正执行的操作。Agent应用中,调用的大模型相当于Agent的大脑,负责推理,而集成的MCP Server,则相当于真正的“手”做一些执行操作。 …

leetcode 883. Projection Area of 3D Shapes 三维形体投影面积-耗时100

Problem: 883. Projection Area of 3D Shapes 三维形体投影面积 解题过程 耗时100%&#xff0c;xy投影数!0的数量&#xff0c;另外两侧投影拿到行最大值、列最大值&#xff0c;累加 Code class Solution { public:int projectionArea(vector<vector<int>>& gr…

400w微型逆变器, 基于stm32g474实现 设计方案,不是成品 带有源代码、原理图(AD...

400w微型逆变器, 基于stm32g474实现 设计方案&#xff0c;不是成品 带有源代码、原理图(AD)、PCB(AD)一、项目概述 本项目是基于STM32G474微控制器实现的400W微型逆变器控制系统&#xff0c;通过精准的硬件外设配置与软件逻辑设计&#xff0c;实现直流到交流的电能转换&#xf…

基于SpringBoot的粮仓管理系统毕设

博主介绍&#xff1a;✌ 专注于Java,python,✌关注✌私信我✌具体的问题&#xff0c;我会尽力帮助你。一、研究目的本研究旨在设计并实现一个基于SpringBoot框架的粮仓管理系统&#xff0c;以满足现代粮仓管理的高效、便捷和智能化需求。具体研究目的如下&#xff1a; 首先&…

也许是集合幂级数

这里会选一些集合幂级数题,但是作者至今不知道集合幂级数是什么东西,所以可能做法不是集合幂级数()。 P13275 好像是区分金银的题? 感觉比省选的岁月简单啊,不知道是不是这个题不是在图上的缘故。 就首先,你考虑…

【后端】【Java】一文详解Spring Boot RESTful 接口统一返回与异常处理实践 - 详解

pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco", "Courier New", …

Spring Boot 3 + GraalVM Native Image 原理:从启动 10秒 到 0.05秒,AOT 编译到底干了什么? - 详解

pre { white-space: pre !important; word-wrap: normal !important; overflow-x: auto !important; display: block !important; font-family: "Consolas", "Monaco", "Courier New", …

2026年知名的翻译企业,天使翻译公司口碑与实力并存 - 工业品牌热点

2026年全球化商务与跨文化交流持续升温,专业翻译服务已成为企业拓展国际市场、个人处理跨境事务的核心支撑。无论是法律合同的精准转译、国际会议的同传保障,还是音视频内容的本地化适配,优质翻译服务商的专业能力直…

基于SpringBoot的进销存系统毕设

博主介绍&#xff1a;✌ 专注于Java,python,✌关注✌私信我✌具体的问题&#xff0c;我会尽力帮助你。一、研究目的本研究旨在设计并实现一个基于SpringBoot框架的进销存系统&#xff0c;以满足现代企业对库存管理、销售管理和采购管理的需求。具体研究目的如下&#xff1a;提高…

SpringAI实践-MCP使用与创建

大多数Agent都不会仅仅满足于只回答问题,它们还需要理解用户意图后,需要做一些真正执行的操作。Agent应用中,调用的大模型相当于Agent的大脑,负责推理,而集成的MCP Server,则相当于真正的“手”做一些执行操作。 …

Python、CSharp、Go、Nextjs,不同框架的性能到底差多少?

前言 不知不觉居然12月了,最近琐事太多,产出并不高,继续整理一下近期的一些笔记吧。 上次我对部署 Django 框架时用的不同服务器进行对比测试,详见:不同Django服务器和部署方式的性能调研 在探索的过程中,我还对…

芯片制造企业如何利用百度WEB编辑器处理PDF技术文档?

河南软件工程大三狗的CMS升级记&#xff1a;从Word粘贴到Latex公式&#xff0c;99元预算的极限操作&#xff01; 一、项目背景&#xff1a;穷学生的倔强 作为一枚即将毕业的大三狗&#xff0c;自己撸了个CMS新闻管理系统&#xff0c;但后台编辑器太挫——从Word复制内容粘贴进…

2025年值得关注的高温塑料回收厂家有哪些?,排行前列的高温塑料回收精选国内优质品牌榜单 - 品牌推荐师

随着全球高温塑料应用场景的持续扩展,工业生产中产生的PEEK、PI、PTFE等特种塑料废弃物规模激增。据行业数据显示,2024年国内高温塑料回收市场规模已突破120亿元,但企业间技术水平、服务能力参差不齐,导致采购方在…

基于SpringBoot框架的社区网格化管理平台

博主介绍&#xff1a;✌ 专注于Java,python,✌关注✌私信我✌具体的问题&#xff0c;我会尽力帮助你。一、研究目的本研究旨在构建一个基于SpringBoot框架的社区网格化管理平台&#xff0c;以实现社区资源的优化配置、提高社区管理效率、提升居民生活质量。具体研究目的如下&am…

2026年不锈钢EP管供应企业推荐,南通地区十大厂家有哪些? - 工业品牌热点

本榜单依托全维度市场调研与真实行业口碑,深度筛选出五家不锈钢EP管领域标杆企业,为半导体、新能源、医药等对流体输送纯度有严苛要求的行业企业选型提供客观依据,助力精准匹配适配的不锈钢EP管供应伙伴。 TOP1 推荐…

基于SpringBoot的社区疫情管理系统毕业设计源码

博主介绍&#xff1a;✌ 专注于Java,python,✌关注✌私信我✌具体的问题&#xff0c;我会尽力帮助你。一、研究目的本研究旨在设计并实现一个基于SpringBoot框架的社区疫情管理系统&#xff0c;以满足当前疫情防控工作的实际需求。具体研究目的如下&#xff1a;构建一个高效、可…

【开题答辩全过程】以 基于SSM框架的药店管理系统的设计与开发为例,包含答辩的问题和答案

个人简介 一名14年经验的资深毕设内行人&#xff0c;语言擅长Java、php、微信小程序、Python、Golang、安卓Android等 开发项目包括大数据、深度学习、网站、小程序、安卓、算法。平常会做一些项目定制化开发、代码讲解、答辩教学、文档编写、也懂一些降重方面的技巧。 感谢大家…

历年CSP-J初赛真题解析 | 2017年CSP-J初赛

​欢迎大家订阅我的专栏:算法题解:C++与Python实现! 本专栏旨在帮助大家从基础到进阶 ,逐步提升编程能力,助力信息学竞赛备战! 专栏特色 1.经典算法练习:根据信息学竞赛大纲,精心挑选经典算法题目,提供清晰的…

基于SpringBoot的社区防疫物资申报系统毕业设计源码

博主介绍&#xff1a;✌ 专注于Java,python,✌关注✌私信我✌具体的问题&#xff0c;我会尽力帮助你。一、研究目的本研究旨在开发一套基于SpringBoot框架的社区防疫物资申报系统&#xff0c;以满足当前疫情防控形势下社区防疫物资管理的需求。具体研究目的如下&#xff1a;提高…

人间美味——胡萝卜炒包菜粉丝

做法极其简单,包菜切丝,胡萝卜切丝,葱切丝,白粉丝泡上。起锅烧油,炒素菜,加一点大油,下葱丝,下两辣椒段,下包菜丝。包菜稍软,下胡萝卜丝、粉丝。翻炒一会,加盐、酱油、味精调味,出锅装盘。 包菜是甜口的,…