介绍前端上传大文件的常见问题和解决方案,分片上传
这样可以避免一次性上传大文件导致的网络超时、内存溢出、进度不可控等问题。
要实现大文件分片上传,通常需要以下几个步骤:
1.通过DOM获取文件对象,并且对文件进行MD5加密(文件内容+文件标题形式),采用SparkMD5进行文件加密;
2.进行分片设置,利用Blob的slice方法进行文件分片处理,并且依次进行上传;
3.当分片文件上传完成后,请求合并接口后端进行文件合并处理即可。
一个简单的js代码示例如下:
// 获取input元素
var input = ("file");
// 获取选择的第一个文件
var file = [0];
// 文件大于5MB时,设置每个分片大小为5MB
var chunkSize = 5 * 1024 * 1024;
// 计算总共有多少个分片
var totalChunks = ( / chunkSize);
// 定义一个数组存放所有的分片
var chunks = [];
// 遍历所有的分片
for (var i = 0; i < totalChunks; i++) {
// 利用slice方法获取每个分片
var start = i * chunkSize;
var end = (, start + chunkSize);
var blob = (start, end);
// 将每个分片添加到数组中
(blob);
}
// 定义一个变量存放当前正在上传的分片索引
var currentChunk = 0;
// 定义一个函数用于递归地上传每个分片
function upload() {
// 如果当前索引等于总数,则说明所有分片都已经上传完成,请求合并接口即可
if (currentChunk === totalChunks) {
("All chunks uploaded!");
// 请求合并接口(省略)
return;
}
// 获取当前要上传的分片对象
var chunk = chunks[currentChunk];
// 创建一个表单数据对象,添加相关信息(如MD5值、索引、总数等)
var formData = new FormData();
("file", chunk);
("md5", file.md5); // 假设已经计算好了MD5值(省略)
("index", currentChunk);
("total", totalChunks);
// 创建一个XMLHttpRequest对象,发送POST请求到服务器端(假设地址为/upload)
var xhr = new XMLHttpRequest();
("POST", "/upload");
// 监听请求状态变化事件
= function () {
if ( === ) {
if ( === 200) {
("Chunk " + currentChunk + " uploaded!");
// 如果成功,则递增索引,并继续调用upload函数
currentChunk++;
upload();
} else {
("Upload failed")
// 如果失败,则重试或者提示错误信息(省略)
}
}
};
// 发送表单数据对象
(formData);
}
// 调用upload函数开始上传第一个分片
upload();
扩充知识库,如有问题请指正