>웹 프론트엔드 >View.js >Vue 및 서버 측 통신 분석: 중단점 재개 구현 방법

Vue 및 서버 측 통신 분석: 중단점 재개 구현 방법

王林
王林원래의
2023-08-11 16:21:091323검색

Vue 및 서버 측 통신 분석: 중단점 재개 구현 방법

Vue와 서버 간의 통신 분석: 중단점 재개 구현 방법

프런트 엔드 개발에서 Vue.js는 매우 인기 있는 JavaScript 프레임워크로, 대화형 빌드를 위한 가볍고 사용하기 쉬운 방법을 제공합니다. 웹 인터페이스. 백엔드 서버와의 통신은 Vue.js 애플리케이션에서 자주 처리해야 하는 중요한 문제입니다.

이 글에서는 Vue와 서버 간의 통신 관점에서 중단점 재개 기능을 구현하는 방법에 대해 설명합니다. 중단점 재개 업로드는 파일 업로드 중에 예기치 않은 중단이 발생하는 경우 다시 시작하지 않고 중단점에서 업로드를 재개할 수 있음을 의미합니다.

먼저 Vue에서 파일 선택 작업을 수행해야 합니다. HTML5의 File API를 사용하면 input 요소의 type 속성을 "file"로 설정하여 파일 선택 기능을 구현할 수 있습니다. 코드 예시는 다음과 같습니다.

<template>
  <div>
    <input type="file" @change="handleFileSelect" />
    <button @click="uploadFile">上传</button>
  </div>
</template>

<script>
export default {
  methods: {
    handleFileSelect(event) {
      // 选择文件的操作
      const file = event.target.files[0];
      // 将文件存储到Vue的data或Vuex中
      this.file = file;
    },
    uploadFile() {
      // 调用上传文件的方法
      this.upload(this.file);
    },
    upload(file) {
      // 实现上传文件的逻辑
      // ...
    }
  }
}
</script>

파일 업로드 과정 중 중단점부터 업로드를 재개하는 기능을 구현해야 합니다. 중단점 재개를 구현하려면 파일 업로드의 기본 원칙을 이해해야 합니다. 파일 전송 프로세스는 일반적으로 파일을 여러 개의 작은 블록으로 나누어 전송하는 것입니다. 각 작은 블록의 크기는 네트워크 상태 및 서버 구성에 따라 조정될 수 있습니다.

먼저 파일의 전체 크기와 업로드된 크기를 가져와야 합니다. HTML5의 파일 API에서 size属性和一些XHR对象的responseText 속성을 사용하여 이를 얻을 수 있습니다. 코드 예는 다음과 같습니다.

upload(file) {
  const chunkSize = 1024 * 1024;
  const totalSize = file.size;
  let loadedSize = 0;

  const readFile = (file, start, end) => {
    const reader = new FileReader();
    const blob = file.slice(start, end);
    reader.onload = (event) => {
      const chunk = event.target.result;

      // 将chunk发送到服务端
      // ...

      loadedSize += chunk.byteLength;

      if (loadedSize < totalSize) {
        const start = loadedSize;
        const end = Math.min(start + chunkSize, totalSize);
        readFile(file, start, end);
      }
    };

    reader.readAsArrayBuffer(blob);
  };

  readFile(file, 0, chunkSize);
}

서버 측에서는 파일의 작은 청크를 수신 및 저장하고 수신된 작은 청크를 기록하여 중단점에서 다운로드를 재개하는 기능을 달성해야 합니다. 일반적인 방법은 Redis와 같은 캐시 데이터베이스를 사용하여 업로드된 작은 청크를 기록하는 것입니다. 코드 예시는 다음과 같습니다.

app.post('/upload', (req, res) => {
  const { chunkNumber, totalChunks } = req.body;
  const file = req.files.file;

  const redisKey = `file:${file.filename}`;

  // 将小块存储到Redis中
  redisClient.hset(redisKey, chunkNumber, file.data, (err) => {
    if (err) {
      res.status(500).send('Internal Server Error');
      return;
    }

    const chunks = Array.from({ length: totalChunks }, (_, i) => i + 1);
    const pendingChunks = chunks.filter((chunk) => !redisClient.hexists(redisKey, chunk));

    if (pendingChunks.length === 0) {
      // 所有小块已上传完毕,开始合并小块
      mergeChunks(redisKey, file.filename);

      res.status(200).send('OK');
    } else {
      res.status(206).send('Partial Content');
    }
  });
});

마지막으로 Vue에서 업로드 프로세스 중에 업로드 재개를 처리해야 합니다. XHR 객체나 Axios와 같은 타사 라이브러리를 사용하여 작은 청크를 서버에 보낼 수 있습니다. 코드 예시는 다음과 같습니다.

upload(file) {
  const chunkSize = 1024 * 1024;
  const totalSize = file.size;
  let loadedSize = 0;

  const uploadChunk = (file, start, end) => {
    const chunk = file.slice(start, end);
    const formData = new FormData();
    formData.append('chunkNumber', Math.ceil(start / chunkSize) + 1);
    formData.append('totalChunks', Math.ceil(totalSize / chunkSize));
    formData.append('file', chunk);

    axios.post('/upload', formData)
      .then((response) => {
        const status = response.status;
        if (status === 200) {
          // 上传完成,可以进行其他操作
          // ...
        } else if (status === 206) {
          loadedSize = end;
          const start = loadedSize;
          const end = Math.min(start + chunkSize, totalSize);
          uploadChunk(file, start, end);
        }
      })
      .catch((error) => {
        console.error(error);
      });
  };

  uploadChunk(file, 0, chunkSize);
}

위 코드 예시를 통해 Vue에서 파일 업로드를 구현하고 중단점 재개 기능을 지원할 수 있습니다. 실제 애플리케이션에서는 업로드 진행률 표시, 재시도 메커니즘 추가 등과 같은 일부 최적화가 이루어질 수도 있습니다.

결론적으로 Vue와 서버 간의 통신을 통해 재개 기능을 구현하는 것은 복잡하지 않습니다. 파일 업로드의 기본 원칙을 숙지한 다음 작은 블록을 분할, 전송 및 기록하면 이력서 업로드 기능을 얻을 수 있으므로 사용자 경험과 파일 전송 안정성이 크게 향상됩니다.

위 내용은 Vue 및 서버 측 통신 분석: 중단점 재개 구현 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.