浏览器上js如何实现上传大文件页面刷新后断点续传?
网友回复
思路很简单,就是将大文件分块切割列出一个编号和清单,然后设置并发数同时上传发给后端,后端根据分块和编号清单数据最后组装还原成原始的大文件,上传的过程中将已完成的批次保存到localstorage中,下次刷新后直接发送未完成部分。
示例代码:
前端 JavaScript 代码:
document.getElementById('fileUpload').addEventListener('change', handleFileSelect, false);
function handleFileSelect(event) {
const file = event.target.files[0];
const chunkSize = 1024 * 1024; // 比如我们设定每个分块的大小为1MB。
let chunks = Math.ceil(file.size / chunkSize);
let currentChunk = 0;
const concurrency = 3; // 并发上传的数目。
let offset = 0; // 用于记录当前并发上传块的位置。
// 读取localStorage中的上传进度。
function getUploadProgress() {
let progress = localStorage.getItem(file.name);
return progress ? parseInt(progress, 10) : 0;
}
// 保存上传进度到localStorage。
function saveUploadProgress(chunk) {
localStorage.setItem(file.name, chunk.toString());
}
// 创建分块上传的函数。
function uploadChunk(chunk) {
var start = chunk * chunkSize;
var end = Math.min(file.size, start + chunkSize);
var formData = new FormData();
formData.append('file', file.slice(start, end)); // 获取文件的某个片段。
formData.append('fileName', ...点击查看剩余70%
ai能写出比黑客还厉害的零日漏洞等攻击工具攻击任意软件系统工程?
js如何获取浏览器的音频上下文指纹、Canvas指纹、WebGL渲染特征?
为啥ai开始抛弃markdown文本,重新偏好html文本了?
网站有没有办法鉴别访问请求是由ai操控chrome-devtools-mcp发出的?
有没有python自动操作浏览器让网站无法鉴别是机器行为?
为啥最新由Meta / 斯坦福 / 哈佛出的ProgramBench基准GPT-5.4、Claude Opus 4.7、Gemini 3.1 Pro 等全部 0% 通过率?
有没有免费的api查询域名是否完成icp工信部备案?
codex用HyperFrames与 Remotion自动做视频那个更好?
claude code中Skill MCP CLI SubAgent Hooks Plugin区别?
浏览器webrtc点对点通讯如何才能走系统代理?


