news 2026/6/23 16:49:04

vue3+Ts实现大文件上传

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
vue3+Ts实现大文件上传

vue3+Ts实现大文件上传

原理
分片上传的原理就像是把一个大蛋糕切成小块一样。

首先就是将上传的大文件分成许多小块,每个小块大小相同,然后逐步上传这些小块到服务器,上传的时候,可以同时上传多个小块,也可以一个一个上传,上传每个小块之后,服务器会保存这些小块,并记录它们的顺序和位置,当我们所有的小块上传完成之后,服务器会把这些小块按照正确的顺序拼接起来,还原成我们的大文件( 下图就是基本的流程 )。

1.项目搭建
实现大文件上传

前端:vue3 + ts

2.读取文件
在我们搭建好之后,通过监听 input 的 change 事件,当提交文件之后,在回调函数中拿到对应文件。

<template><div><h1>大文件上传</h1><input type="file"@change="handleUpload"></div></template><script setup lang="ts">consthandleUpload=(e:Event)=>{// console.log((e.target as HTMLInputElement).files); // 伪数组constfiles=(e.targetasHTMLInputElement).files// 如果拿到文件返回if(!files)return//读取文件console.log(files[0]);}</script>

3.文件分片
文件分片我们会用到 Blob 对象的 slice 方法,我们在上一步获得的 File 对象,它是继承于 Blob 的。

// 1MB = 1024KB = 1024 * 1024BconstCHUNK_SIZE=1024*1024// 1MB// 在这里进行文件的分片constcreateChunks=(file:File)=>{// 设置开始的节点let cur=0// 空数组,用来存储分割后的文件块let chunks=[]// 循环遍历文件,将它分割成多个块while(cur<file.size){// 提取 start 到 end 之间的内容constblob=file.slice(cur,cur+CHUNK_SIZE)// 提取出来的内容添加到 chunks 数组中chunks.push(blob)// 更新读取的位置cur+=CHUNK_SIZE}// 返回文件块的数组returnchunks}consthandleUpload=(e:Event)=>{// console.log((e.target as HTMLInputElement).files); // 伪数组constfiles=(e.target asHTMLInputElement).files// 如果拿到文件返回if(!files)return//读取文件console.log(files[0])// 文件切片constchunks=createChunks(files[0])console.log(chunks);}

4.hash 算法
切片完成之后开始计算 hash 值,需要安装 spark-md5 工具,因为计算 hash 值需要用到。

constcalculateHash=(chunks:Blob[])=>{returnnewPromise((resolve)=>{lettarget:Blob[]=[]// 在每次计算哈希之前清空target数组// 创建一个新的SparkMD5对象,用于计算MD5哈希值constspark=newSparkMD5.ArrayBuffer();// 遍历每个Blob片段chunks.forEach((chunk,index)=>{// 如果是第一个或最后一个片段,则将其完整地加入target数组if(index===0||index===chunks.length-1){target.push(chunk);}else{// 如果是中间的片段,则只取片段的前2字节、中间2字节和最后2字节target.push(chunk.slice(0,2));target.push(chunk.slice(CHUNK_SIZE/2,CHUNK_SIZE/2+2));target.push(chunk.slice(CHUNK_SIZE-2,CHUNK_SIZE));}});// 创建一个新的FileReader对象constfileReader=newFileReader();// 读取target数组中的Blob数据为ArrayBufferfileReader.readAsArrayBuffer(newBlob(target));// 当FileReader读取完成时触发fileReader.onload=(e)=>{// 将读取的结果追加到SparkMD5对象中spark.append((e.targetasFileReader).resultasArrayBuffer);// 计算最终的MD5哈希值consthash=spark.end();// 清空target数组,避免重复使用旧数据target=[];// 解析结果resolve(hash);};});};

5.文件合并
合并需要我们前端去进行请求到后端服务器,并且传输需要的数据,然后进行操作

constmergeRequest=()=>{fetch('http://localhost:3000/merge',{method:"POST",headers:{'Content-Type':'application/json'},body:JSON.stringify({fileHash:fileHash.value,fileName:fileName.value,size:CHUNK_SIZE})}).then(()=>{alert('合并成功!')})}
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/22 18:48:28

Joy-Con Toolkit终极指南:全方位手柄定制与性能优化方案

Joy-Con Toolkit终极指南&#xff1a;全方位手柄定制与性能优化方案 【免费下载链接】jc_toolkit Joy-Con Toolkit 项目地址: https://gitcode.com/gh_mirrors/jc/jc_toolkit Joy-Con Toolkit作为一款功能强大的开源手柄定制工具&#xff0c;专为任天堂Switch玩家提供专…

作者头像 李华
网站建设 2026/6/23 20:39:15

Joy-Con Toolkit专业级手柄控制:深度解析与实战应用

Joy-Con Toolkit专业级手柄控制&#xff1a;深度解析与实战应用 【免费下载链接】jc_toolkit Joy-Con Toolkit 项目地址: https://gitcode.com/gh_mirrors/jc/jc_toolkit Joy-Con Toolkit作为一款开源手柄控制工具&#xff0c;通过专业级的技术架构和丰富的功能模块&…

作者头像 李华
网站建设 2026/6/23 18:36:33

CowabungaLite终极指南:免费解锁iOS 15+设备完整自定义功能

CowabungaLite是一款专为iOS 15设备设计的强大自定义工具箱&#xff0c;无需越狱即可实现深度个性化设置。这款免费工具让普通用户也能轻松调整iPhone和iPad的外观与功能&#xff0c;打造独一无二的移动体验。无论你是想要更换应用图标、自定义状态栏显示&#xff0c;还是启用隐…

作者头像 李华
网站建设 2026/6/23 3:24:21

精通iOS自定义:完全掌控你的个性化设备体验

精通iOS自定义&#xff1a;完全掌控你的个性化设备体验 【免费下载链接】CowabungaLite iOS 15 Customization Toolbox 项目地址: https://gitcode.com/gh_mirrors/co/CowabungaLite 还在为千篇一律的iOS界面感到厌倦&#xff1f;想要打造真正属于自己的设备却无从下手&…

作者头像 李华
网站建设 2026/6/23 18:36:12

NBTExplorer:3个简单步骤掌握我的世界数据编辑终极工具

NBTExplorer&#xff1a;3个简单步骤掌握我的世界数据编辑终极工具 【免费下载链接】NBTExplorer A graphical NBT editor for all Minecraft NBT data sources 项目地址: https://gitcode.com/gh_mirrors/nb/NBTExplorer 想要彻底掌控《我的世界》的游戏数据吗&#xf…

作者头像 李华
网站建设 2026/6/22 22:19:44

微信数据解密终极指南:WechatDecrypt工具5步轻松上手

微信数据解析和本地解密工具WechatDecrypt是专为微信用户设计的专业数据解密解决方案。这款工具专注于本地化数据解析&#xff0c;能够安全高效地解密微信SQLite数据库中的加密通信内容&#xff0c;所有操作均在用户本地设备完成&#xff0c;从根本上保障数据隐私安全。 【免费…

作者头像 李华