大文件上传是一个比较重要的交互场景,
如上传入库比较大的Excel表格数据、上传影音文件等。

如果文件体积比较大,或者网络条件不好时,上传的时间会比较长(要传输更多的报文,丢包重传的概率也更大),用户不能刷新页面,只能耐心等待请求完成。

1.利用上传控件 input type="file" 绑定一个change事件,在回调中通过事件对象的e.target.files拿到这个文件对象,进行文件对象的slice方法,进行切片,一个大文件就转换成多个小文件了。
2.借助 http 的可并发性,同时上传多个切片。这样从原本传一个大文件,同时传多个小的文件切片,可以减少上传时间
3.断点续传:前端在上传切片时,给对应的切片添加一个唯一标识符,上传到后端,服务器需要记住已上传的切片,这样下次就可以跳过之前已经上传的部分
4.oss服务器需要配置白名单,否则前端调用上传接口直传OSS服务器会报错


freeman_Tian
12 声望2 粉丝