分片上传,分片合并

面是一种基于前端分片上传,后端合并的方法的代码实现:

前端代码(HTML + JavaScript):

html 复制代码
<input type="file" id="fileInput">
<button onclick="uploadFile()">Upload</button>

<script>
function uploadFile() {
  var fileInput = document.getElementById('fileInput');
  var file = fileInput.files[0];

  var chunkSize = 5 * 1024 * 1024; //每个分片大小为5MB
  var totalChunks = Math.ceil(file.size / chunkSize); //总分片数
  var currentChunk = 0; //当前上传的分片序号

  var reader = new FileReader();
  reader.onload = function(e) {
    var xhr = new XMLHttpRequest();
    xhr.open('POST', '/upload', true);
    xhr.setRequestHeader('Content-Type', 'application/octet-stream');
    xhr.setRequestHeader('X-Chunk-Number', currentChunk);
    xhr.setRequestHeader('X-Total-Chunks', totalChunks);

    xhr.onload = function() {
      currentChunk++;
      if (currentChunk < totalChunks) {
        uploadChunk();
      } else {
        alert('File uploaded successfully!');
      }
    };

    xhr.send(e.target.result);
  };

  function uploadChunk() {
    var start = currentChunk * chunkSize;
    var end = Math.min(start + chunkSize, file.size);
    var chunk = file.slice(start, end);
    reader.readAsArrayBuffer(chunk);
  }

  uploadChunk();
}
</script>

后端代码(Node.js + Express):

javascript 复制代码
const express = require('express');
const app = express();
const fs = require('fs');

app.use(express.json());

app.post('/upload', (req, res) => {
  const chunkNumber = req.headers['x-chunk-number'];
  const totalChunks = req.headers['x-total-chunks'];
  const fileStream = fs.createWriteStream('uploaded_file', { flags: 'a' });

  req.pipe(fileStream);

  if (chunkNumber == totalChunks - 1) {
    fileStream.on('finish', () => {
      res.sendStatus(200);
    });
  }
});

app.listen(3000, () => {
  console.log('Server started on port 3000');
});

前端使用了HTML的&lt;input type="file">标签和JavaScript的FileReader对象来实现分片读取文件,并通过XMLHttpRequest发送每个分片到后端。

后端使用Node.js和Express框架,接收到每个分片后将其写入到文件中,当收到最后一个分片时,触发finish事件,表示文件上传完成。

相关推荐
玉宇夕落8 分钟前
JavaScript 执行状态全景图:从调用栈到事件循环,深入理解异步机制
javascript
牧野星辰11 分钟前
eslint你不懂的都在这里,不信你进来看嘛~
前端·eslint
FogLetter11 分钟前
设计模式奇幻漂流:从单例孤岛到工厂流水线
前端·设计模式
ohyeah11 分钟前
深入理解 JavaScript 数组:从创建到遍历的完整指南
前端·javascript
逛逛GitHub13 分钟前
GitHub 开源 AI 好玩神器,自动记录你的一天。
前端·github
绝无仅有17 分钟前
某东互联网大厂的Redis面试知识点分析
后端·面试·架构
洛克希德马丁18 分钟前
Qt 配置Webassemble环境
开发语言·qt·webassembly·emscripten·emsdk
武子康19 分钟前
Java-167 Neo4j CQL 实战:CREATE/MATCH 与关系建模速通 案例实测
java·开发语言·数据库·python·sql·nosql·neo4j
自由的好好干活21 分钟前
C#桌面框架与Qt对比及选型(国产操作系统开发视角)
开发语言·qt·c#
upward_tomato26 分钟前
python中模拟浏览器操作之playwright使用说明以及打包浏览器驱动问题
开发语言·python