目录
流程简说
获取文件的 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)上传文件在Web开发中经常会遇到的一个问题是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函数处理上传文件在开发Web应用中,文件上传是一个常见的需求。PHP提供了一个方便的函数move_uploaded_file(),用于处理上传的文件。本文将向您介绍如何使用这个函数来实现文件上传功能。一、准备工作在开始之前,确保您的PHP环境已经配置好了文件上传的参数。您可以通过打开php.in

用Golang函数简化文件上传处理 用Golang函数简化文件上传处理 May 02, 2024 pm 06:45 PM

答案:是,Golang提供的函数可以简化文件上传处理。详情:MultipartFile类型提供对文件元数据和内容的访问。FormFile函数从表单请求中获取特定文件。ParseForm和ParseMultipartForm函数用于解析表单数据和多部分表单数据。使用这些函数简化了文件处理流程,让开发者专注于业务逻辑。

See all articles