news 2026/6/9 21:35:11

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/9 1:05:18

Zotero文献去重完全指南:智能合并插件使用详解

Zotero文献去重完全指南&#xff1a;智能合并插件使用详解 【免费下载链接】ZoteroDuplicatesMerger A zotero plugin to automatically merge duplicate items 项目地址: https://gitcode.com/gh_mirrors/zo/ZoteroDuplicatesMerger 文献管理工作中最令人困扰的问题莫过…

作者头像 李华
网站建设 2026/6/9 19:55:00

罗技PUBG鼠标宏终极配置指南:5步实现完美压枪

想要在绝地求生中拥有职业选手般的稳定枪法吗&#xff1f;罗技PUBG鼠标宏正是你需要的终极辅助工具。这款专为罗技游戏鼠标设计的智能脚本&#xff0c;能够自动控制后坐力&#xff0c;让你的射击精准度得到显著提升。无论你是FPS游戏新手还是资深玩家&#xff0c;只需按照本指南…

作者头像 李华
网站建设 2026/6/10 1:00:16

NBTExplorer:解锁我的世界数据编辑的隐藏技巧

你是否曾经好奇那些精心设计的我的世界服务器是如何实现各种神奇功能的&#xff1f;答案就藏在游戏的NBT数据中。NBTExplorer作为一款强大的图形化NBT编辑器&#xff0c;让你能够深入探索和修改《我的世界》的核心数据结构&#xff0c;从简单的物品属性到复杂的世界生成规则&am…

作者头像 李华
网站建设 2026/6/9 13:49:29

Joy-Con Toolkit 深度使用指南:从问题诊断到高级配置

Joy-Con Toolkit 深度使用指南&#xff1a;从问题诊断到高级配置 【免费下载链接】jc_toolkit Joy-Con Toolkit 项目地址: https://gitcode.com/gh_mirrors/jc/jc_toolkit 作为一名资深游戏外设顾问&#xff0c;我经常遇到玩家对Joy-Con手柄的各种困扰。今天我将带你全面…

作者头像 李华
网站建设 2026/6/4 15:28:45

快速理解Arduino创意作品中HC-SR501人体感应配置

从零玩转HC-SR501&#xff1a;让Arduino“看见”你的存在 你有没有想过&#xff0c;一个几块钱的小模块&#xff0c;能让灯自动亮起、让警报悄然启动、甚至唤醒沉睡的智能系统&#xff1f;在无数创客作品中&#xff0c;这种“灵性”的源头&#xff0c;往往就是那个不起眼的 HC…

作者头像 李华