목차
Process Brief
파일의 MD5 고유 식별 코드 가져오기
文件切片
获取文件名 name
分片文件大小 chunkSize
文件切片 chunkList 列表
切片总数 chunks
切片大小  size
合并
웹 프론트엔드 View.js vue가 파일 분할 업로드를 구현하는 방법에 대한 간략한 분석

vue가 파일 분할 업로드를 구현하는 방법에 대한 간략한 분석

Mar 24, 2023 pm 07:40 PM
vue.js 파일 업로드 파일 조각

vue가 파일 분할 업로드를 구현하는 방법에 대한 간략한 분석

실제 개발 프로젝트 과정에서 상대적으로 큰 파일을 업로드해야 하는 경우가 있는데, 그러면 업로드 속도가 상대적으로 느려지므로 백그라운드에서 파일 조각을 업로드하려면 프런트엔드가 필요할 수 있습니다. 매우 간단합니다. 즉, 예를 들어 1G 파일 스트림을 여러 개의 작은 파일 스트림으로 자른 다음 작은 파일 스트림을 각각 전달하도록 인터페이스를 요청합니다.

Process Brief

파일 조각 가져오기를 구현하려면 먼저 elementUI 또는 기본 업로드 태그를 사용하여 파일 파일 스트림을 얻습니다. 그런 다음 이 파일이 이전에 업로드되었는지 확인해야 합니다. 이 파일에 대한 고유 식별자를 백엔드에 제출한 다음 백엔드에 문제가 있는지 여부를 알려주도록 해야 합니다. 이때 백엔드는 세 가지 상태를 반환할 수 있습니다.

  • 파일을 사용할 수 없습니다. , 모든 파일을 업로드해야 합니다.

  • 이 파일은 이미 존재하므로 프런트 엔드에서 다시 업로드할 필요가 없습니다.

  • 본 파일의 일부가 업로드 되었으며, 업로드되지 않은 부분도 계속해서 업로드 하셔야 합니다.

이 단계를 구현하는 중요한 매개 변수는 파일의 MD5 식별 코드를 사용하는 것입니다. 따라서 먼저 이 파일의 MD5 고유 식별 코드를 가져와야 합니다. [관련 권장사항: vuejs 동영상 튜토리얼, 웹 프론트엔드 개발]

우리는 파일을 업로드해야 하거나 부분적으로 업로드해야 할 때 슬라이싱 작업을 수행해야 한다는 것을 알고 있습니다. 예를 들어 파일의 바이너리 바이트 스트림은 총 1G이고 일반적으로 5M씩 한 조각으로 절단되므로 1G 파일인 경우 205개의 조각으로 절단해야 합니다. 물론 마지막 조각이 반드시 5M일 필요는 없습니다. 그런 다음 파일을 부분적으로 업로드하기 위한 인터페이스로 이동하여 파일을 부분적으로 가져오기 위한 요청을 시작합니다.

우선, 205개의 조각난 데이터 스트림을 제출한 후 백그라운드에서 이를 병합해야 한다는 점을 분명히 해두세요. 즉, 조각에서 제출한 205개의 파일 스트림을 큰 파일로 결합하여 저장해야 합니다. 이렇게 하면 백그라운드 병합이 완료된 파일이 결국 가져오기를 위해 제출하게 됩니다. 백엔드를 병합해야 하고 이를 하나씩 업로드하므로 각 조각이 파일의 어느 부분인지 백엔드에 알려야 합니다. , 오른쪽? 따라서 샤딩 요청을 제출할 때 일반적으로 다음 매개변수를 전달해야 합니다.

  • chunk: 현재 샤드 번호, 일반적으로 0부터 시작합니다.
  • chunkSize: 조각의 크기, 일반적으로 5M, 5242880바이트입니다.
  • chunks: 총 샤드 수입니다.
  • file: 현재 조각의 파일 스트림입니다.
  • md5: 조각화되지 않은 전체 파일의 MD5 고유 식별 코드입니다.
  • name: 현재 파일의 이름입니다.
  • size: 현재 샤드 크기(마지막 블록이 반드시 5M가 아닐 경우).

이렇게 하면 백엔드가 최종 파일을 병합하는 방법을 알 수 있습니다. 물론 백엔드에서 특정 필드를 정의해야 하며, 그런 다음 이 아이디어에 따라 적절하게 연결할 수 있습니다.

알겠습니다. 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)
      }
    });
  }
}
로그인 후 복사

그러면 필요할 때 사용할 수 있습니다. 물론 여기에 반환되는 것은 .then에서 직접 얻을 수 있는 Promise입니다. .then 就可以获取了。

或者是使用 async、 await

또는 async, wait를 사용하세요. 🎜
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 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

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 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

Laravel을 사용하여 파일 업로드 및 다운로드 기능을 구현하는 방법 Laravel을 사용하여 파일 업로드 및 다운로드 기능을 구현하는 방법 Nov 02, 2023 pm 04:36 PM

Laravel을 사용하여 파일 업로드 및 다운로드 기능을 구현하는 방법 Laravel은 웹 애플리케이션을 보다 쉽고 효율적으로 개발할 수 있도록 다양한 기능과 도구를 제공하는 인기 있는 PHP 웹 프레임워크입니다. 일반적으로 사용되는 기능 중 하나는 파일 업로드 및 다운로드입니다. 이 글에서는 Laravel을 사용하여 파일 업로드 및 다운로드 기능을 구현하는 방법을 소개하고 구체적인 코드 예제를 제공합니다. 파일 업로드 파일 업로드란 로컬 파일을 서버에 업로드하여 저장하는 것을 말합니다. Laravel에서는 파일 업로드를 사용할 수 있습니다.

Workerman 문서에서 파일 업로드 및 다운로드 구현 Workerman 문서에서 파일 업로드 및 다운로드 구현 Nov 08, 2023 pm 06:02 PM

Workerman 문서에서 파일 업로드 및 다운로드를 구현하려면 특정 코드 예제가 필요합니다. 소개: Workerman은 간단하고 효율적이며 사용하기 쉬운 고성능 PHP 비동기 네트워크 통신 프레임워크입니다. 실제 개발에서 파일 업로드 및 다운로드는 일반적인 기능 요구 사항입니다. 이 기사에서는 Workerman 프레임워크를 사용하여 파일 업로드 및 다운로드를 구현하는 방법을 소개하고 구체적인 코드 예제를 제공합니다. 1. 파일 업로드: 파일 업로드란 로컬 컴퓨터에 있는 파일을 서버로 전송하는 작업을 말합니다. 다음이 사용됩니다

gRPC를 사용하여 Golang에서 파일 업로드를 구현하는 방법은 무엇입니까? gRPC를 사용하여 Golang에서 파일 업로드를 구현하는 방법은 무엇입니까? Jun 03, 2024 pm 04:54 PM

gRPC를 사용하여 파일 업로드를 구현하는 방법은 무엇입니까? 요청 및 응답 메시지를 포함하여 지원 서비스 정의를 만듭니다. 클라이언트에서는 업로드할 파일이 열리고 청크로 분할된 다음 gRPC 스트림을 통해 서버로 스트리밍됩니다. 서버 측에서는 파일 청크가 수신되어 파일에 저장됩니다. 서버는 파일 업로드가 완료된 후 업로드 성공 여부를 나타내는 응답을 보냅니다.

Java 파일 업로드 예외(FileUploadException)를 해결하는 방법 Java 파일 업로드 예외(FileUploadException)를 해결하는 방법 Aug 18, 2023 pm 12:11 PM

Java 파일 업로드 예외(FileUploadException)를 해결하는 방법 웹 개발에서 자주 발생하는 문제 중 하나는 FileUploadException(파일 업로드 예외)입니다. 파일 크기 제한 초과, 파일 형식 불일치, 잘못된 서버 구성 등 다양한 이유로 인해 발생할 수 있습니다. 이 문서에서는 이러한 문제를 해결하는 몇 가지 방법을 설명하고 해당 코드 예제를 제공합니다. 업로드된 파일의 크기를 제한하세요. 대부분의 경우 파일 크기를 제한하세요.

PHP를 사용하여 FTP 파일 업로드 진행 표시줄을 구현하는 방법 PHP를 사용하여 FTP 파일 업로드 진행 표시줄을 구현하는 방법 Jul 30, 2023 pm 06:51 PM

PHP를 사용하여 FTP 파일 업로드 진행 표시줄을 구현하는 방법 1. 배경 소개 웹사이트 개발에서 파일 업로드는 일반적인 기능입니다. 대용량 파일을 업로드하는 경우 사용자 경험을 개선하기 위해 사용자에게 파일 업로드 프로세스를 알 수 있도록 업로드 진행률 표시줄을 표시해야 하는 경우가 많습니다. 이 기사에서는 PHP를 사용하여 FTP 파일 업로드 진행률 표시줄 기능을 구현하는 방법을 소개합니다. 2. FTP 파일 업로드 진행률 표시줄 구현의 기본 아이디어 FTP 파일 업로드의 진행률 표시줄은 일반적으로 업로드된 파일의 크기와 업로드된 파일의 크기를 계산하여 계산됩니다.

Laravel에서 파일 업로드 및 처리: 사용자가 업로드한 파일 관리하기 Laravel에서 파일 업로드 및 처리: 사용자가 업로드한 파일 관리하기 Aug 13, 2023 pm 06:45 PM

Laravel의 파일 업로드 및 처리: 사용자 업로드 파일 관리 소개: 파일 업로드는 최신 웹 애플리케이션에서 매우 일반적인 기능 요구 사항입니다. Laravel 프레임워크에서는 파일 업로드 및 처리가 매우 간단하고 효율적입니다. 이 글에서는 파일 업로드 확인, 저장, 처리, 표시 등 Laravel에서 사용자가 업로드한 파일을 관리하는 방법을 소개합니다. 1. 파일 업로드 파일 업로드는 클라이언트에서 서버로 파일을 업로드하는 것을 말합니다. Laravel에서는 파일 업로드를 처리하기가 매우 쉽습니다. 첫 번째,

PHP 파일 업로드 가이드: move_uploaded_file 함수를 사용하여 업로드된 파일을 처리하는 방법 PHP 파일 업로드 가이드: move_uploaded_file 함수를 사용하여 업로드된 파일을 처리하는 방법 Jul 30, 2023 pm 02:03 PM

PHP 파일 업로드 가이드: move_uploaded_file 함수를 사용하여 업로드된 파일을 처리하는 방법 웹 애플리케이션 개발에서 파일 업로드는 일반적인 요구 사항입니다. PHP는 업로드된 파일을 처리하기 위해 편리한 move_uploaded_file() 함수를 제공합니다. 이 글에서는 이 기능을 사용하여 파일 업로드 기능을 구현하는 방법을 소개합니다. 1. 준비 시작하기 전에 PHP 환경이 파일 업로드 매개변수로 구성되었는지 확인하세요. php.in을 열어서 이 작업을 수행할 수 있습니다.

Golang 기능으로 파일 업로드 처리 단순화 Golang 기능으로 파일 업로드 처리 단순화 May 02, 2024 pm 06:45 PM

답변: 네, Golang은 파일 업로드 처리를 단순화하는 기능을 제공합니다. 세부 정보: MultipartFile 유형은 파일 메타데이터 및 콘텐츠에 대한 액세스를 제공합니다. FormFile 함수는 양식 요청에서 특정 파일을 가져옵니다. ParseForm 및 ParseMultipartForm 함수는 양식 데이터와 다중 부분 양식 데이터를 구문 분석하는 데 사용됩니다. 이러한 기능을 사용하면 파일 처리 프로세스가 단순화되고 개발자가 비즈니스 로직에 집중할 수 있습니다.

See all articles