当前位置: 首页 > news >正文

前端实现边下载文件边上传

问题记录原因:

因为需要实现网络文件的上传,结果是由前端实现,方式是一边下载,一遍上传文件,小文件直接上传,大文件进行切片,切片大小和下载大小有关,特此记录。

1.实现方案

fetch进行网络连接的下载,在请求的返回对象中调用response.body.getReader(),这里是读取文件流,便于监听,读取的方式为reader.read(),它的返回对象中包含,文件对象和完成状态,这样就能实现,循环执行下载的动作知道,状态为完成停止。

2.步骤代码

1)下载

const response: any = await fetch(downloadUrl);
const reader = response.body.getReader();
// 读取响应的文件字节数
const contentLength = +response.headers.get('Content-Length');

2)上传

使用MD5计算文件的hash进行分片上传

let receivedLength = 0;
// 分片上传的话需要计算每一片文件的hash,我们使用MD5
const spark = new SparkMD5.ArrayBuffer();
while(true) {const {done, value} = await reader.read();if (done) {// 计算整个文件的hashconst finalHash = spark.end();console.log('下载&上传完成:', finalHash);break;}// 更新整个文件的hashspark.append(value);receivedLength += value.length;console.log(`下载进度: ${receivedLength} / ${contentLength}`);// 创建一个新的SparkMD5实例来处理当前分片const chunkHash = SparkMD5.ArrayBuffer.hash(value); // 计算当前分片的hashconst offset = receivedLength - value.length;// console.log(contentLength, offset, chunkHash, hash, value.length);// 上传这个分片,这里执行接口...
}

 contentLength, offset, chunkHash, hash, value.length,这些参数是分片上传所需要的,依次是:

文件的大小,分片的偏移量,每一片的hash(这个参数可选),整个文件的hash(这个需要提前计算出来),每一个分片的大小;

3.拓展

1)计算大文件的hash

可以参考:【文件比较】前端上传比较内容及名字-CSDN博客

2)content-type类型与文件类型的对应关系

不全面,只是涵盖大多文件类型:

const getFileTypeByContentType = (contentType: string) => {let type = ['image/jpeg', 'image/pjpeg'].includes(contentType) ? 'jpg':['image/png'].includes(contentType) ? 'png':['image/gif'].includes(contentType) ? 'gif':['image/svg+xml'].includes(contentType) ? 'svg':['video/mp4'].includes(contentType) ? 'mp4':['video/quicktime'].includes(contentType) ? 'mov':['text/html'].includes(contentType) ? 'html':['text/markdown'].includes(contentType) ? 'md':['text/plain'].includes(contentType) ? 'txt':['text/csv'].includes(contentType) ? 'csv':['application/json'].includes(contentType) ? 'json':['application/x-yaml', 'text/yaml'].includes(contentType) ? 'yaml':['application/pdf'].includes(contentType) ? 'pdf':['application/msword'].includes(contentType) ? 'doc':['application/vnd.openxmlformats-officedocument.wordprocessingml.document'].includes(contentType) ? 'docx':['application/vnd.openxmlformats-officedocument.spreadsheetml.sheet'].includes(contentType) ? 'xlsx':['application/vnd.ms-excel'].includes(contentType) ? 'xls':['application/vnd.openxmlformats-officedocument.presentationml.presentation'].includes(contentType) ? 'pptx':['application/zip'].includes(contentType) ? 'zip':'';return type
}

http://www.lryc.cn/news/410173.html

相关文章:

  • 滑线变阻器的优缺点是什么?
  • K8s大模型算力调度策略的深度解析
  • Unity Transform组件实现动画:基础与进阶技巧
  • 基于深度学习的图像与文本结合
  • windows安全加固
  • 网络安全是什么?怎么入门网络安全?
  • 语义分割介绍
  • Unity Editor免登录启动 无需UnityHub
  • Redis实战篇(黑马点评)笔记总结
  • vulntarget-b
  • Axure Web端元件库:构建高效互动网页的基石
  • mac OS matplotlib missing from font(s) DejaVu Sans
  • 在 .NET 中使用 Elasticsearch:从安装到实现搜索功能的完整指南
  • Ecovadis认证的步骤需要怎么做?
  • git sendemail使用
  • 【React】package.json 文件详解
  • 【嵌入式开发】Keil下载安装
  • 【vluhub】elasticsearch漏洞
  • 七言-绝美崇州
  • C++11新增特性及右值引用
  • MySQL --- 表的操作
  • MongoDB 基础知识
  • HDFS原理
  • 49、PHP 实现堆排序
  • 鸿蒙9+在TV端焦点封装控制
  • 操作系统课程设计:(JAVA)进程管理系统(附源码zip,jdk11,IDEA Ultimate2024 )
  • 机器学习 | 回归算法原理——随机梯度下降法
  • LeetCode 面试经典 150 题 | 位运算
  • postMessage 收到消息类型 “webpackWarnings“
  • 计算机基础(day1)