基于js管理大文件上传以及断点续传,程序员翻身之路

headers: {

‘Content-Type’: ‘application/x-www-form-urlencoded’

}

});

if (+data.code === 0) {

alert(恭喜您,文件上传成功,您可以基于 ${data.servicePath} 地址去访问~~);

return;

}

throw data.codeText;

} catch (err) {

alert(‘很遗憾,文件上传失败,请您稍后再试~~’);

} finally {

upload_button_select.classList.remove(‘loading’);

}

});

复制代码

上面这个例子中后端收到前端传过来的文件会对它进行生成一个随机的名字,存下来,但是有些公司会将这一步放在前端进行,生成名字后一起发给后端,接下来我们来实现这个功能

前端生成文件名传给后端

这里就需要用到上面提到的插件SparkMD5[1],具体怎么用就不做赘述了,请参考文档

  • 封装读取文件流的方法

const changeBuffer = file => {

return new Promise(resolve => {

let fileReader = new FileReader();

fileReader.readAsArrayBuffer(file);

fileReader.onload = ev => {

let buffer = ev.target.result,

spark = new SparkMD5.ArrayBuffer(),

HASH,

suffix;

spark.append(buffer);

// 得到文件名

HASH = spark.end();

// 获取后缀名

suffix = /.([a-zA-Z0-9]+)$/.exec(file.name)[1];

resolve({

buffer,

HASH,

suffix,

filename: ${HASH}.${suffix}

});

};

});

};

复制代码

  • 上传服务器相关代码

upload_button_upload.addEventListener(‘click’, async function () {

if (checkIsDisable(this)) return;

if (!_file) {

alert(‘请您先选择要上传的文件~~’);

return;

}

changeDisable(true);

// 生成文件的HASH名字

let {

filename

} = await changeBuffer(_file);

let formData = new FormData();

formData.append(‘file’, _file);

formData.append(‘filename’, filename);

instance.post(‘/upload_single_name’, formData).then(data => {

if (+data.code === 0) {

alert(文件已经上传成功~~,您可以基于 ${data.servicePath} 访问这个资源~~);

return;

}

return Promise.reject(data.codeText);

}).catch(reason => {

alert(‘文件上传失败,请您稍后再试~~’);

}).finally(() => {

changeDisable(false);

upload_abbre.style.display = ‘none’;

upload_abbre_img.src = ‘’;

_file = null;

});

});

复制代码

上传进度管控


这个功能相对来说比较简单,文中用到的请求库是axios,进度管控主要基

  • 10
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
现在大部分的网站使用的是标准HTML的上传方式来上传文件。一般情况下标准HTML方式在网页中只能上传4MB左右的文件,如果访问的用户比较多的时侯这种方式容易上传失败。虽然标准HTML上传方式开发起来比较简单,但是这种方式用户体验比较差,上传的文件大小受到限制,所以如果我们需要上传上百或者更大的上G的文件时,HTML标准上传方式是无法满足我们的需求的。 而另一方面,随着互联网行业的发展用户产生的新的需求也越来越多,同时对用户体验也提出了更高的要求,传统的HTML方式也越来越难已满足新的用户需求。现在大部分的用户有文件批量上传的需求,希望只通过点击一次鼠标就能够批量的上传多张图片,而不是一张张的选择文件上传,这样操作即浪费时间又非常烦琐。 近年来,由于数码和影视行业的迅猛发展刺激了用户对大文件的上传需求,现在越来越多的用户希望能够通过WEB的方式上传更大的文件,比如电影和图片。这些类型的文件通常都非常大,一般都在500MB以上,高清的影视文件至少在1G以上。这样的大文件是根本无法通过标准HTML方式来上传的。 不仅如此,由于国内网络环境比较特殊,有许多地区的网络不够稳定,在上传文件的过程中可能会发生断网的情况。如果用户正在上传一个1000MB的文件,已经上传了500MB,这时网络出现问题上传中止了。那么下一次用户需要要重新上传前面的500MB,而不是从500MB开始上传,这将浪费用户的许多时间。 新颖网络HTTP文件断点续传控件是专门用于解决HTTP大文件上传的需求而开发的产品。通过我们的HttpPartition模块用户能够非常方便的一次性选择超过200个的文件。而且我们升级了用户体验,用户现在不仅能够通过点击按钮来选择多个文件,还可以通过HttpDroper来拖拽文件甚至是文件夹。 现在我们能够轻松支持2G左右的大文件上传。为了减轻服务器的压力在HttpUploader模块中我们并不是一次上传2G的数据,而是将2G化分为小的数据块,每次向服务器上传约128KB左右的数据。同时在每次上传的数据中附带了文件大小,起始位置,文件MD5等信息。对于开发人员来说,有了这些信息,断点续传功能将会变的和普通的文件上传功能一样简单。 相信新颖网络HTTP断点续传控件能够帮助您赢利市场。 产品介绍:[url=http://www.cnblogs.com/xproer/archive/2012/02/17/2355440.html][/url]
前端大文件上传指的是上传文件大小较大,超过了常规的文件上传限制(例如2MB)。这时需要使用特殊的上传方式,常见的有两种: 1. 分片上传:将大文件分成多个小文件,分别上传到服务器,并在服务器端将这些小文件合并成一个完整的文件。 2. 断点续传:将大文件分成多个小文件,分别上传到服务器,上传过程中若出现网络中断或其他原因导致上传失败,可以从失败的位置继续上传,避免重新上传整个文件。 实现前端大文件上传断点续传需要使用一些第三方库或框架,例如: 1. Plupload:一个基于Flash和HTML5的文件上传库,支持分片上传和断点续传。 2. Resumable.js:一个基于HTML5的文件上传库,支持断点续传。 3. jQuery-File-Upload:一个基于jQuery的文件上传插件,支持分片上传和断点续传。 在使用这些库或框架实现大文件上传断点续传时,需要注意以下几点: 1. 服务器端需要支持分片上传和断点续传,否则无法实现这些功能。 2. 分片上传和断点续传需要对文件进行切片,这可能会影响上传速度和文件完整性,需要做好相应的处理。 3. 断点续传需要记录上传进度,以便在上传失败时能够从失败的位置继续上传。 总之,前端大文件上传断点续传是一个比较复杂的问题,需要使用一些专门的库或框架来实现,同时需要注意一些细节问题,才能保证上传效率和上传成功率。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值