欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 新闻 > 资讯 > 大文件上传实现

大文件上传实现

2025/3/18 23:01:23 来源:https://blog.csdn.net/weixin_44801790/article/details/146293658  浏览:    关键词:大文件上传实现

大文件上传实现

1.将文件切割成多个小文件
2.将小文件上传到服务器
3.后端将小文件合并成一个大文件

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8" /><meta name="viewport" content="width=device-width, initial-scale=1.0" /><title>大文件上传</title></head><body><input type="file" id="file" /><button id="upload">上传</button><script>const fileInput = document.getElementById("file");const uploadBtn = document.getElementById("upload");uploadBtn.addEventListener("click", () => {const file = fileInput.files[0];const chunkSize = 1024 * 1024; // 每个切片的大小为1MBconst chunks = Math.ceil(file.size / chunkSize); // 计算切片的数量for (let i = 0; i < chunks; i++) {const start = i * chunkSize;const end = Math.min(start + chunkSize, file.size);const chunk = file.slice(start, end); // 切割文件// 将切片上传到服务器uploadChunk(chunk, i, chunks);}});function uploadChunk(chunk, index, totalChunks) {const formData = new FormData();formData.append("file", chunk);formData.append("index", index);formData.append("totalChunks", totalChunks);// 打印切片的信息console.log(`切片${index + 1}/${totalChunks}${chunk.size}字节`);// 发送POST请求将切片上传到服务器//   fetch("/upload", {//     method: "POST",//     body: formData,//   })//     .then((res) => res.json())//     .then((data) => {//       console.log(data);//     });}</script></body>
</html>

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

热搜词