基于React、Ts、nodejs的大文件上传分片、暂停等功能的实现

背景

最近由于业务需求, 需要上传大文件, 为了让用户上传起来更快速, 不禁想起最近比较火的大文件上传, 于是不如实践一下, 写出符合业务需求的大文件上传, 不仅样式可以自定义, 各种功能细节点都在自己掌握之中, 由于本次做的是一个demo,大家可以根据自己的需要去进行更改,都很容易的!本文使用 React 框架来搭建, 在 Antd 框架基础之上来写样式, 后端采用 node.js 来提供接口. 感兴趣的可以继续看下去.咻~

内容主要大致分为两部分:

1、前端逻辑代码;

2、node接口

相信大家都做过很多次的类似于上传文件的功能,不知道有没有碰到过这种困扰:正在上传~80%error:网络不佳,停止上传! ,如果说是个小文件也就罢了,几个g的文件,重新上传的时候还要从头再来。心态爆炸,不想干了 ,那么好,以下这个办法可以完全解决上传终止后,再次上传给它接上,正在上传~81%,哎!很神奇吧!哈哈哈哈~!

首先将文件进行分片可以按照比例分成十份,不分大小,从而进行分片上传;然后进行计算文件的hash值,通过对比hash判断文件上传到哪一步,如果文件已经存在数据库中,那么就秒传,嗖!

使用 Web Worker + SparkMD5 根据文件内容生成 hash 值
javascript 复制代码
let worker = new Worker("/hash.js");
//......
const spark = new self.SparkMD5.ArrayBuffer();
let percent = 0;
let perSize = 100 / partList.length;
let buffers = await Promise.all(
  partList.map(
    ({ chunk, size }) =>
      new Promise((resolve) => {
        const reader = new FileReader();
        reader.readAsArrayBuffer(chunk);
        reader.onload = function (event) {
          percent += perSize;
          self.postMessage({ percent: Number(percent.toFixed(2)) });
          resolve(event.target.result);
        };
      })
  )
);
buffers.forEach((buffer) => spark.append(buffer));
self.postMessage({ percent: 100, hash: spark.end() });

唔唔喔喔~~~~~~~累了不想写了,GitHub链接在下方,有感兴趣的直接clone下来,直接跑就完啦!

Github地址:github.com/li-0801/rea...

ok!收工!

相关推荐
酒尘&5 小时前
JS数组不止Array!索引集合类全面解析
开发语言·前端·javascript·学习·js
学历真的很重要5 小时前
VsCode+Roo Code+Gemini 2.5 Pro+Gemini Balance AI辅助编程环境搭建(理论上通过多个Api Key负载均衡达到无限免费Gemini 2.5 Pro)
前端·人工智能·vscode·后端·语言模型·负载均衡·ai编程
用户47949283569156 小时前
"讲讲原型链" —— 面试官最爱问的 JavaScript 基础
前端·javascript·面试
用户47949283569156 小时前
2025 年 TC39 都在忙什么?Import Bytes、Iterator Chunking 来了
前端·javascript·面试
2401_860319526 小时前
在React Native鸿蒙跨平台开发中实现 二叉搜索树,如何实现一些基本的遍历方法,如中序遍历,中序遍历按顺序访问左子树、根节点、右子树
react native·react.js·harmonyos
大怪v7 小时前
【Virtual World 04】我们的目标,无限宇宙!!
前端·javascript·代码规范
狂炫冰美式8 小时前
不谈技术,搞点文化 🧀 —— 从复活一句明代残诗破局产品迭代
前端·人工智能·后端
xw58 小时前
npm几个实用命令
前端·npm
!win !8 小时前
npm几个实用命令
前端·npm
代码狂想家8 小时前
使用openEuler从零构建用户管理系统Web应用平台
前端