news 2026/4/3 3:14:21

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/3/26 3:59:31

Zotero文献管理新体验:一键批量导入PDF文件夹

Zotero文献管理新体验&#xff1a;一键批量导入PDF文件夹 【免费下载链接】zotero-addons Zotero add-on to list and install add-ons in Zotero 项目地址: https://gitcode.com/gh_mirrors/zo/zotero-addons 你是否曾经为整理散落在电脑各处的PDF文献而头疼&#xff1…

作者头像 李华
网站建设 2026/3/23 15:54:01

GetQzonehistory:一键永久保存QQ空间所有回忆

GetQzonehistory&#xff1a;一键永久保存QQ空间所有回忆 【免费下载链接】GetQzonehistory 获取QQ空间发布的历史说说 项目地址: https://gitcode.com/GitHub_Trending/ge/GetQzonehistory 你是否也曾担心QQ空间里的青春记忆会随着时间流逝&#xff1f;那些年少的感慨、…

作者头像 李华
网站建设 2026/3/31 15:48:14

罗技鼠标宏终极配置指南:告别压枪困扰

还在为绝地求生中枪口乱飘而烦恼&#xff1f;罗技鼠标宏让你轻松实现自动压枪&#xff0c;告别手抖困扰&#xff01;这款专为罗技游戏鼠标设计的Lua脚本工具&#xff0c;能显著提升射击稳定性&#xff0c;助你成为战场王者。 【免费下载链接】logitech-pubg PUBG no recoil scr…

作者头像 李华
网站建设 2026/3/27 0:50:19

罗技鼠标压枪宏终极配置指南:从新手到高手的完整教程

罗技鼠标压枪宏终极配置指南&#xff1a;从新手到高手的完整教程 【免费下载链接】logitech-pubg PUBG no recoil script for Logitech gaming mouse / 绝地求生 罗技 鼠标宏 项目地址: https://gitcode.com/gh_mirrors/lo/logitech-pubg 还在为绝地求生中枪口上跳而烦恼…

作者头像 李华
网站建设 2026/3/27 17:12:27

Joy-Con Toolkit完全指南:免费开源手柄自定义终极解决方案

Joy-Con Toolkit完全指南&#xff1a;免费开源手柄自定义终极解决方案 【免费下载链接】jc_toolkit Joy-Con Toolkit 项目地址: https://gitcode.com/gh_mirrors/jc/jc_toolkit 作为一款专为任天堂Switch手柄量身打造的开源控制软件&#xff0c;Joy-Con Toolkit为游戏玩…

作者头像 李华
网站建设 2026/3/30 8:08:16

arm64-v8a启动流程深度剖析:从上电到内核初始化

arm64-v8a 启动流程深度解析&#xff1a;从复位向量到内核接管 你有没有遇到过这样的场景&#xff1f;板子上电后串口毫无输出&#xff0c;或者 U-Boot 卡在某个阶段不动了&#xff0c;又或者内核启动时直接崩溃却看不到任何日志。这时候&#xff0c;如果你只知道“重启试试”或…

作者头像 李华