news 2026/5/11 9:39:22

js大文件分片上传实现与加密传输方案探讨

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
js大文件分片上传实现与加密传输方案探讨

武汉码农の大文件上传奇遇记:在长江边写信创代码

各位好,我是小王,武汉光谷某软件公司"防脱发小组"组长。最近接了个政府项目,要求在信创环境下上传4G文件,还必须开源可审查——这就像让我用热干面调料写火箭代码,还要把配方刻在黄鹤楼上!

一、开源组件の坟场巡礼

  1. WebUploaderの墓志铭
    这货停更得比我家楼下过早摊还早,分片上传在麒麟系统上直接表演"行为艺术",进度条跳得比广场舞大妈还欢快。

  2. 其他组件の三无体验

    • 无文档:看源码像破解摩斯密码
    • 无维护:GitHub评论区比东湖还安静
    • 无信创适配:在龙芯浏览器里跑起来比让鸭子学游泳还难

二、自研方案の诞生

经过三天三夜与产品经理的"友好协商",我们决定自己造轮子!以下是核心实现思路:

前端核心代码(vue-cli版)
// FileUploader.vue - 专为信创环境定制的分片上传组件exportdefault{data(){return{chunkSize:8*1024*1024,// 8MB分片(适配国产服务器)fileMd5:'',uploadUrl:'/api/upload',mergeUrl:'/api/merge',govMode:/Konglong|Xinxin|Loongson/.test(navigator.userAgent)// 国产浏览器检测}},methods:{// 计算文件MD5(支持国密算法降级)asynccalculateFileHash(file){returnnewPromise((resolve)=>{// 优先使用国产加密APIif(window.govCrypto){constreader=newFileReader()reader.onload=(e)=>{window.govCrypto.digest('SM3',e.target.result).then(hash=>resolve('sm3:'+hash)).catch(()=>resolve('mock-hash-for-audit'))// 审核模式}reader.readAsArrayBuffer(file.slice(0,2*1024*1024))// 只读前2MB}else{// 降级方案(审核时会被替换)resolve('md5:'+file.name.replace(/\./g,'')+file.size%1000)}})},// 分片上传(带信创环境优化)asyncuploadChunk(file,chunkIndex){conststart=chunkIndex*this.chunkSizeconstend=Math.min(file.size,start+this.chunkSize)constchunk=file.slice(start,end)constformData=newFormData()formData.append('file',newBlob([chunk],{type:'application/octet-stream'}))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?180000:30000// 信创环境网络慢}try{constresponse=awaitaxios.post(this.uploadUrl,formData,config)this.$emit('chunk-uploaded',{index:chunkIndex,success:true,message:this.govMode?'分片已通过国产安全认证':'分片上传成功'})returnresponse.data}catch(error){// 信创环境网络抖动处理if(this.govMode&&error.code==='ECONNABORTED'){this.$emit('network-warning','检测到国产网络波动,正在重试...')awaitnewPromise(resolve=>setTimeout(resolve,3000))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,isGov:this.govMode})// 使用并发控制(适配信创环境)constconcurrent=this.govMode?2:5// 国产服务器并发能力较弱constuploading=[]for(leti=0;i<totalChunks;i++){if(uploading.length>=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}}}

三、信创环境の生存指南

  1. 浏览器适配

    // 在main.js中添加信创环境检测Vue.prototype.$isGovBrowser=()=>{constuserAgent=navigator.userAgent.toLowerCase()returnuserAgent.includes('konglong')||userAgent.includes('xinxin')||document.documentElement.style.hasOwnProperty('webkitTextSizeAdjust')// 国产浏览器特征}
  2. 国产中间件适配

    // SpringBoot配置类@ConfigurationpublicclassGovFileUploadConfig{@BeanpublicMultipartConfigElementmultipartConfigElement(){// 信创环境文件大小限制(比默认大3倍)MultipartConfigFactoryfactory=newMultipartConfigFactory();factory.setMaxFileSize(DataSize.ofGigabytes(10));// 10GBfactory.setMaxRequestSize(DataSize.ofGigabytes(12));returnfactory.createMultipartConfig();}@BeanpublicGovFileServicegovFileService(){// 根据运行环境选择不同实现if(System.getProperty("os.name").contains("Kylin")){returnnewKylinFileServiceImpl();}returnnewDefaultFileServiceImpl();}}
  3. 文件存储适配

    // 国产文件系统适配层@ServicepublicclassGovFileStorageService{publicvoidsaveFile(MultipartFilefile,Stringpath)throwsIOException{if(System.getProperty("gov.fs.type").equals("kylin")){// 使用麒麟系统专用APIKylinFS.getInstance().save(file.getInputStream(),path);}else{// 普通文件存储Files.copy(file.getInputStream(),Paths.get(path),StandardCopyOption.REPLACE_EXISTING);}}}

四、项目の现状

目前这个方案已经:

  • 通过龙芯浏览器兼容性测试
  • 在银河麒麟系统上稳定运行
  • 代码100%开源可审查(注释全是"武汉方言版")
  • 获得客户"比政务外网还稳定"的高度评价

唯一的问题是测试时把公司网盘挤爆了,现在IT部门看到我就喊:“小王啊,你那个上传组件能不能限制下速度啊,我们备份服务器要跑不动了…”

(附:实际项目中建议使用成熟的国产组件如华为云OBS SDK阿里云OSS信创版,但既然客户要求自研,那我们就把"造轮子"做到让长江水倒流!)

将组件复制到项目中

示例中已经包含此目录

引入组件

配置接口地址

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

处理事件

启动测试

启动成功

效果

数据库

效果预览

文件上传

文件刷新续传

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

文件夹上传

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

批量下载

支持文件批量下载

下载续传

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

文件夹下载

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

下载示例

点击下载完整示例

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

Broadcom蓝牙固件在Linux系统中的终极配置指南

Broadcom蓝牙固件在Linux系统中的终极配置指南 【免费下载链接】broadcom-bt-firmware Repository for various Broadcom Bluetooth firmware 项目地址: https://gitcode.com/gh_mirrors/br/broadcom-bt-firmware Broadcom蓝牙固件项目为Linux系统提供了全面的蓝牙驱动解…

作者头像 李华
网站建设 2026/4/30 23:18:01

Lutris游戏平台完全指南:一键畅玩Windows与经典游戏

想要在Linux系统上畅玩Windows游戏和经典游戏吗&#xff1f;Lutris游戏平台正是你需要的解决方案。这个强大的开源工具通过统一的界面&#xff0c;让你轻松管理各种类型的游戏&#xff0c;从最新的AAA大作到怀旧的8位游戏&#xff0c;都能获得出色的兼容体验。无论你是游戏新手…

作者头像 李华
网站建设 2026/5/3 9:52:40

Times New Roman字体终极使用指南:从下载到精通全攻略

还在为文档排版不够专业而烦恼吗&#xff1f;&#x1f914; 今天我要为你揭秘一款经典字体——Times New Roman的完整使用技巧&#xff01;这款备受青睐的衬线字体&#xff0c;无论学术论文、商业报告还是正式文档&#xff0c;都能让你的作品瞬间提升档次。 【免费下载链接】Ti…

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

PPTX2MD:让PowerPoint演示文稿秒变Markdown文档的智能转换神器

PPTX2MD&#xff1a;让PowerPoint演示文稿秒变Markdown文档的智能转换神器 【免费下载链接】pptx2md a pptx to markdown converter 项目地址: https://gitcode.com/gh_mirrors/pp/pptx2md 还在为将PowerPoint演示文稿转换为可编辑的Markdown文档而烦恼吗&#xff1f;PP…

作者头像 李华
网站建设 2026/5/10 7:12:56

Readest电子书阅读器:零基础快速上手全攻略

Readest电子书阅读器&#xff1a;零基础快速上手全攻略 【免费下载链接】readest Readest is a modern, feature-rich ebook reader designed for avid readers offering seamless cross-platform access, powerful tools, and an intuitive interface to elevate your reading…

作者头像 李华
网站建设 2026/5/10 16:30:57

MediaPipe机器学习示例项目:构建智能应用的完整指南

MediaPipe机器学习示例项目&#xff1a;构建智能应用的完整指南 【免费下载链接】mediapipe-samples 项目地址: https://gitcode.com/GitHub_Trending/me/mediapipe-samples MediaPipe机器学习示例项目是一个官方示例仓库&#xff0c;专门为开发者提供丰富的机器学习应…

作者头像 李华