欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

React大文件分片上傳原理及方案

 更新時(shí)間:2023年08月08日 09:16:42   作者:Kobe_G  
前端進(jìn)行大文件分片上傳的方案幾乎都是利用Blob.prototype.slice方法對(duì)文件進(jìn)行分片,用數(shù)組將每一個(gè)分片存起來(lái),最后將分片發(fā)給后端,本文給大家介紹React大文件分片上傳方案,感興趣的朋友跟隨小編一起看看吧

最近做了大文件(文件夾)分片上傳的需求,記錄一下。

原理:

前端進(jìn)行大文件分片上傳的方案幾乎都是利用Blob.prototype.slice方法對(duì)文件進(jìn)行分片,用數(shù)組將每一個(gè)分片存起來(lái),最后將分片發(fā)給后端。由于并發(fā)的原因,需要給每個(gè)分片給定index,方便后端進(jìn)行拼接。

方案:

我在做需求之前看了網(wǎng)上的一些方案,大多數(shù)是前端進(jìn)行分片、發(fā)送分片,在發(fā)送完所有分片請(qǐng)求之后,再給后端發(fā)送一個(gè)合并文件的請(qǐng)求。但其實(shí)也可以在發(fā)送分片之前就先把文件的一些信息(整個(gè)文件的MD5、分片個(gè)數(shù)、分片大小、分片的MD5等等)先發(fā)給后端,后端在接收完分片之后就可以自動(dòng)合并了。

antd Upload

先介紹一下antd中的Upload組件,Upload的API中有一個(gè)beforeUpload,該函數(shù)接收兩個(gè)參數(shù),file和fileList,file是一個(gè)文件對(duì)象,類型是File,屬于Blob的子類,所以可以直接調(diào)用file.slice進(jìn)行分片。值得注意的是,beforeUpload這個(gè)鉤子可能會(huì)調(diào)用多次,比如你上傳一個(gè)文件夾,文件夾中有5個(gè)文件,那么它就會(huì)調(diào)用5次。
file文件對(duì)象長(zhǎng)這樣:

在這里插入圖片描述

文件分片

上面已經(jīng)說(shuō)到,可以直接調(diào)用file.slice,所以可以在beforeUpload中進(jìn)行分片,比如:

const createFileChunk = async (file: Blob, size: number) => {
  const fileChunkList = [];
  let cur = 0;
  let index = 0;
  while (cur < file.size) {
    const chunk = file.slice(cur, cur + size);
    fileChunkList.push({ file: chunk, index }); // 可以加入很多信息。比如MD5
    cur += size;
    index += 1;
  }
  return fileChunkList;
};
const beforeUpload = (file: Blob) => {
	const fileChunkList = createFileChunk(file);
	// 其他自定義邏輯
	return true
}

MD5

在分片中加入MD5主要是為了后端收到文件后進(jìn)行校驗(yàn),要注意的是,Blob對(duì)象是不能夠作為MD5函數(shù)的參數(shù)的,一般是用FileReader把Blob讀成二進(jìn)制(arrayBuffer對(duì)象)之后再傳入MD5函數(shù),比如:

import md5 from 'md5';
const getFileMd5 = (chunk: Blob) => {
  return new Promise((resolve, reject) => {
    const reader = new FileReader();
    reader.readAsArrayBuffer(chunk);
    reader.onload = (data) => {
      resolve(md5(new Uint8Array(data.target?.result as any))); //類型化數(shù)組
    };
    reader.onerror = () => {
      reject(new Error('Failed to read file!'));
    };
  });
};

關(guān)于FileReader、ArrayBuffer和類型化數(shù)組可以看 http://www.dbjr.com.cn/html5/726792.html

發(fā)送分片請(qǐng)求

二進(jìn)制文件的上傳請(qǐng)求是不能用json傳的,如果一定要用json,可以把文件轉(zhuǎn)成base64(這里不適用,適用于小文件)。

這里附上二進(jìn)制文件轉(zhuǎn)base64的方法:

const fileToBase64 = (file: Blob): Promise<string> => {
  return new Promise((resolve) => {
    const reader = new FileReader();
    reader.readAsDataURL(file);
    reader.onload = (e) => {
      if (e && e.target && e.target.result) {
        resolve(e.target.result);
      }
    };
  });
};

對(duì)于文件上傳的請(qǐng)求,需要用到FormData,http請(qǐng)求頭中的Content-Type要設(shè)置為multipart/form-data,比如:

  const formData = new FormData();
  formData.append('file', file); // file為Blob對(duì)象

然后把formData作為http請(qǐng)求的body就可以進(jìn)行發(fā)送了

顯示上傳進(jìn)度

我這里使用的方案是 已上傳的分片數(shù)量 / 總的分片數(shù)量,這是一種大概的上傳進(jìn)度,忽略了單個(gè)分片上傳的進(jìn)度,因?yàn)槭谴笪募?,也沒有必要計(jì)算得十分準(zhǔn)確。

此外還有錯(cuò)誤重傳、限制請(qǐng)求并發(fā)數(shù)、斷點(diǎn)續(xù)傳等邏輯,本文不再闡述。

到此這篇關(guān)于React大文件分片上傳方案的文章就介紹到這了,更多相關(guān)React大文件分片上傳內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • React Native自定義標(biāo)題欄組件的實(shí)現(xiàn)方法

    React Native自定義標(biāo)題欄組件的實(shí)現(xiàn)方法

    今天講一下如何實(shí)現(xiàn)自定義標(biāo)題欄組件,我們都知道RN有一個(gè)優(yōu)點(diǎn)就是可以組件化,在需要使用該組件的地方直接引用并傳遞一些參數(shù)就可以了,這種方式確實(shí)提高了開發(fā)效率。對(duì)React Native自定義標(biāo)題欄組件的實(shí)現(xiàn)方法感興趣的朋友參考下
    2017-01-01
  • webpack 2的react開發(fā)配置實(shí)例代碼

    webpack 2的react開發(fā)配置實(shí)例代碼

    本篇文章主要介紹了webpack 2的react開發(fā)配置實(shí)例代碼,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來(lái)看看吧
    2017-07-07
  • 關(guān)于react+antd樣式不生效問題的解決方式

    關(guān)于react+antd樣式不生效問題的解決方式

    最近本人在使用Antd開發(fā)時(shí)遇到些問題,所以下面這篇文章主要給大家介紹了關(guān)于react+antd樣式不生效問題的解決方式,文中通過圖文以及實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-07-07
  • React引入css的幾種方式及應(yīng)用小結(jié)

    React引入css的幾種方式及應(yīng)用小結(jié)

    這篇文章主要介紹了React引入css的幾種方式及應(yīng)用小結(jié),操作styled組件的樣式屬性,可在組件標(biāo)簽上定義屬性、也可以通過attrs定義屬性,本文通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2024-03-03
  • 將React+Next.js的項(xiàng)目部署到服務(wù)器的方法

    將React+Next.js的項(xiàng)目部署到服務(wù)器的方法

    本文詳細(xì)介紹了將React+Next.js項(xiàng)目部署到服務(wù)器的步驟,包括服務(wù)器環(huán)境準(zhǔn)備、項(xiàng)目配置與構(gòu)建、啟動(dòng)服務(wù)、配置Nginx反向代理、HTTPS配置、驗(yàn)證與監(jiān)控以及高級(jí)優(yōu)化,感興趣的朋友一起看看吧
    2025-03-03
  • React html中使用react的兩種方式

    React html中使用react的兩種方式

    這篇文章主要介紹了React html中使用react的兩種方式,本文給大家提到了React pwa的配置代碼,給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-04-04
  • react新版本生命周期鉤子函數(shù)及用法詳解

    react新版本生命周期鉤子函數(shù)及用法詳解

    這篇文章主要介紹了react新版本生命周期鉤子函數(shù)及用法詳解,本文通過示例圖文相結(jié)合給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-04-04
  • React使用高德地圖的實(shí)現(xiàn)示例(react-amap)

    React使用高德地圖的實(shí)現(xiàn)示例(react-amap)

    這篇文章主要介紹了React使用高德地圖的實(shí)現(xiàn)示例(react-amap),文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-04-04
  • React實(shí)現(xiàn)單向數(shù)據(jù)流的方法

    React實(shí)現(xiàn)單向數(shù)據(jù)流的方法

    本文主要介紹了React實(shí)現(xiàn)單向數(shù)據(jù)流的方法
    2023-04-04
  • React中redux的使用詳解

    React中redux的使用詳解

    Redux 是一個(gè)狀態(tài)管理庫(kù),它可以幫助你管理應(yīng)用程序中的所有狀態(tài),Redux的核心概念之一是Store,它表示整個(gè)應(yīng)用程序的狀態(tài),這篇文章給大家介紹React中redux的使用,感興趣的朋友一起看看吧
    2023-12-12

最新評(píng)論