目錄
流程簡說
取得文件的MD5 唯一識別碼
文件切片
获取文件名 name
分片文件大小 chunkSize
文件切片 chunkList 列表
切片总数 chunks
切片大小  size
合并
首頁 web前端 Vue.js 淺析vue怎麼實現檔案切片上傳

淺析vue怎麼實現檔案切片上傳

Mar 24, 2023 pm 07:40 PM
vue.js 文件上傳 文件切片

淺析vue怎麼實現檔案切片上傳

在實際開發專案過程中有時候需要上傳比較大的文件,然後呢,上傳的時候相對來說就會慢一些,so,後台可能會要求前端進行文件切片上傳,很簡單哈,就是把比如說1個G的檔案流切割成若干個小的檔案流,然後分別請求介面傳遞這個小的檔案流。

流程簡說

實作檔案切片導入,首先我們使用elementUI 也好,原生的upload 標籤也好,取得到檔案file 檔案流,然後需要做的一件事情就是知道這個文件之前有沒有上傳過,我們需要向後台提交一個這個文件唯一的標識符,然後讓後端告訴我們這個問題後台有沒有,這時候,後端可能會返回我們三種狀態:

  • 檔案沒有,需要全部上傳。

  • 這個檔案存在了,前端不需要再上傳。

  • 這個檔案上傳了一部分,需要繼續把沒有上傳的部分上傳。

只有這三種狀態,實作這個步驟的一個重要參數就是這個檔案的唯一標識符,這個標識符,使用的就是這個檔案的 MD5 標識碼。所以我們首先需要取得這個檔案的 MD5 唯一識別碼。 【相關推薦:vuejs影片教學web前端開發

#我們知道檔案需要上傳或是需要部分上傳的時候,我們就需要進行切片操作了。這個就很簡單了,例如檔案的二進位位元流一共1個G,然後一般是5M 切一片,所以說如果是1個G 的檔案需要切205 片,當然最後一片不一定是5M,然後我們走文件分片上傳的接口,發起文件分片導入的請求。

首先明確一點,就是我們把這205 個分片資料流提交完,後台是需要合併的,就是把我們分片提交的在這205 個文件流合成一個大的文件保存起來,這樣,後台合併完的文件就是我們最終要提交導入的文件,既然後端需要合併,我們又是一片一片上傳的,總得讓後端知道每一片是這個文件的哪一部分吧?所以說我們提交分片請求的時候一般需要傳遞這幾個參數:

  • chunk: 目前是第幾個分片,一般是從 0 開始。
  • chunkSize:分片的大小,一般是5M,即5242880位元組。
  • chunks:總共有多少分片。
  • file:目前分片的檔案流。
  • md5:整個檔案的 MD5 唯一識別碼,不是分片的哈。
  • name:目前檔案的名稱。
  • size:目前分片大小(如果最後一塊不一定是 5M)。

這樣後端就知道怎麼去合併最後的檔案了。當然了具體的欄位需要後端去定義,然後我們就按照這個思路去對應的對接就可以了。

OK,等我們  205 個分片資料全部提交完成,需要再走一個接口,就是通知後端,好了,我前端分片都傳完了,你可以合併文件了。

然後後端合併完成,檔案匯入成功!

取得文件的MD5 唯一識別碼

很多人說哈,MD5 不是加密嘛,其實這個想法在這裡不是很對哈,MD5 是加密不了文件的,只會產生一個唯一的編碼,這麼說呢,哎喲,就當是加密吧,但是別妄想提交一個MD5 編碼就當把加密的文件提交給後端了哈,首先這個就是一個字符串,不是加密的文件,第二,這個玩意並不能解密。我們這裡只是給文件產生一個唯一標識符,讓後端判斷伺服器之前有沒有存在過這個文件,如果唯一標識有的話,就說明之前上傳過,直接用之前的就可以了,就不用再次上傳了,畢竟如果文件修改了,這個MD5 識別碼是會變的。

怎麼取得檔案的 MD5 編碼很簡單哈,在vue裡面需要使用一個函式庫 spark-md5

一句指令安裝

npm install --save spark-md5
登入後複製

然後我們可以寫一個方法來封裝一下。

建立一個fileMd5Sum.js 檔案:

import SparkMD5 from 'spark-md5'

export default {
  // md5值计算
  fileMd5Sum(file) {
    return new Promise(resolve => {
      let fileReader = new FileReader()
      let Spark = new SparkMD5.ArrayBuffer()
      fileReader.readAsArrayBuffer(file)
      fileReader.onload = function (e) {
        Spark.append(e.target.result)
        let md5 = Spark.end()
        resolve(md5)
      }
    });
  }
}
登入後複製

然後在需要使用的時候就可以使用了,當然這裡回傳的是一個Promise,直接.then 就可以獲取了。

或是使用 async、 await

let md5Str = await this.fileMd5Sum.fileMd5Sum(file.raw)
登入後複製

文件切片

获取了文件MD5标识码,后台说需要提交,我们就需要把文件切片,从头提交或者是提交部分操作了,如果不需要的话直接走合并接口就可以了,走合并接口其实是告诉后台合并,我们要做的就是把其他除了文件相关的其他参数传递给后台罢了。

文件切片就是类似于字符串截取,这里是截取字节。获取需要的参数我们自己些就可以了。假设我们使用 elementUI 文件上传组件获取到了文件 file

获取文件名 name

let fileName = file.name  // 获取文件名
登入後複製

分片文件大小 chunkSize

let chunkSize = 5 * 1024 * 1024   // 一般是 5M,具体多少看后端想要多少
登入後複製

文件切片 chunkList 列表

            let chunkList = []  // 创建一个数组用来存储每一片文件流数据
            if (file.size < chunkSize) {  // 如果文件大小小于5M就只有一片,不用切都
              chunkList.push(file.raw.slice(0))  // 文件流从第一个字节直接截取到最后就可以了
            } else {  // 如果文件大小大于5M 就需要切片了
              var start = 0, end = 0  // 创建两个变量 开始位置 结束位置
              while (true) {  // 循环
                end += chunkSize  // 结束为止 = 结束位置 + 每片大小
                let blob = file.raw.slice(start, end)  // 文件流从开始位置截取到结束位置
                start += chunkSize  // 截取完,开始位置后移
                if (!blob.size) {  // 如果截取不到了就退出
                  break;
                }
                chunkList.push(blob)  // 把截取的每一片数据保存到数组
              }
            }
登入後複製

切片总数 chunks

我们上一步已经获取到每片文件流的数组了,所以说呢,直接获取就可以了。

let chunks = chunkList.length
登入後複製

切片大小 size

我们是按照 5 M 切割的,所以说每片大小应该是 5 * 1024 * 1024 但是呢,不对,因为最后一片不一定就是正好的 5 M,所以说我们可直接 .size 获取一下大小。比如:

chunkList[0].size  // 获取第1片大小
登入後複製

参数都找齐了,然后就走切片提交接口开始提交数据就可以了。

合并

当我们把分片数据全部提交成功,后台返回说切片文件保存成功之后,我们就可以走最后一个接口,提交就可以了。

好了,就这样!完成!!!

(学习视频分享:vuejs入门教程编程基础视频

以上是淺析vue怎麼實現檔案切片上傳的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解鎖Myrise中的所有內容
4 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

實作Workerman文件中的文件上傳與下載 實作Workerman文件中的文件上傳與下載 Nov 08, 2023 pm 06:02 PM

實現Workerman文件中的文件上傳與下載,需要具體程式碼範例引言:Workerman是一款高效能的PHP非同步網路通訊框架,具備簡潔、高效、易用等特點。在實際開發中,文件上傳和下載是常見的功能需求,本文將介紹如何使用Workerman框架實現文件的上傳和下載,並給出具體的程式碼範例。一、檔案上傳:檔案上傳是指將本機上的檔案傳輸至伺服器端的操作。下面是使用

如何利用Laravel實作檔案上傳與下載功能 如何利用Laravel實作檔案上傳與下載功能 Nov 02, 2023 pm 04:36 PM

如何利用Laravel實現文件上傳和下載功能Laravel是一個流行的PHPWeb框架,提供了豐富的功能和工具,使得開發Web應用程式更加簡單和有效率。其中一個常用的功能就是檔案上傳和下載。本文將介紹如何利用Laravel實作檔案上傳和下載功能,並提供具體的程式碼範例。文件上傳文件上傳是指將本機的文件上傳到伺服器上儲存。在Laravel中,我們可以使用檔案上傳

如何解決Java檔案上傳異常(FileUploadException) 如何解決Java檔案上傳異常(FileUploadException) Aug 18, 2023 pm 12:11 PM

如何解決Java檔案上傳異常(FileUploadException)上傳檔案在網路開發中經常會遇到的一個問題是FileUploadException(檔案上傳例外)。它可能會因各種原因而出現,例如檔案大小超過限制、檔案格式不符或伺服器配置不正確等。本文將介紹一些解決這些問題的方法,並提供相應的程式碼範例。限制上傳檔案的大小在大多數場景下,限製檔案大小

如何在 Golang 中使用 gRPC 實作檔案上傳? 如何在 Golang 中使用 gRPC 實作檔案上傳? Jun 03, 2024 pm 04:54 PM

如何使用gRPC實作檔案上傳?建立配套服務定義,包括請求和回應訊息。在客戶端,開啟要上傳的檔案並將其分成區塊,然後透過gRPC串流傳輸到服務端。在服務端,接收文件區塊並將其儲存到文件中。服務端在文件上傳完成後發送回應,指示上傳是否成功。

如何用PHP實作FTP檔案上傳進度條 如何用PHP實作FTP檔案上傳進度條 Jul 30, 2023 pm 06:51 PM

如何用PHP實作FTP檔案上傳進度條一、背景介紹在網站開發中,檔案上傳是常見的功能。而對於大檔案的上傳,為了提高使用者體驗,我們常常需要向使用者顯示一個上傳進度條,讓使用者知道檔案上傳的進程。本文將介紹如何使用PHP實作FTP檔案上傳進度條的功能。二、FTP檔案上傳進度條的實現方法基本思路FTP檔案上傳的進度條實現,通常是透過計算上傳的檔案大小和已上傳檔案大小

Laravel中的文件上傳和處理:管理用戶上傳的文件 Laravel中的文件上傳和處理:管理用戶上傳的文件 Aug 13, 2023 pm 06:45 PM

Laravel中的檔案上傳與處理:管理使用者上傳的檔案引言:在現代Web應用程式中,檔案上傳是很常見的功能需求。在Laravel框架中,文件上傳和處理變得非常簡單和有效率。本文將介紹如何在Laravel中管理使用者上傳的文件,包括文件上傳的驗證、儲存、處理和顯示。一、文件上傳文件上傳是指將文件從客戶端上傳到伺服器端。在Laravel中,檔案上傳非常容易處理。首先,

PHP檔案上傳指南:如何使用move_uploaded_file函數處理上傳文件 PHP檔案上傳指南:如何使用move_uploaded_file函數處理上傳文件 Jul 30, 2023 pm 02:03 PM

PHP檔案上傳指南:如何使用move_uploaded_file函數處理上傳檔案在開發網頁應用程式中,檔案上傳是常見的需求。 PHP提供了一個方便的函數move_uploaded_file(),用來處理上傳的檔案。本文將向您介紹如何使用這個函數來實作檔案上傳功能。一、準備工作在開始之前,請確保您的PHP環境已經配置了檔案上傳的參數。您可以透過打開php.in

用Golang函數簡化檔案上傳處理 用Golang函數簡化檔案上傳處理 May 02, 2024 pm 06:45 PM

答案:是,Golang提供的函數可以簡化檔案上傳處理。詳情:MultipartFile類型提供對文件元資料和內容的存取。 FormFile函數從表單請求中取得特定檔案。 ParseForm和ParseMultipartForm函數用於解析表單資料和多部分錶單資料。使用這些函數簡化了文件處理流程,讓開發者專注於業務邏輯。

See all articles