前后端配合续传

一、首先,为了引入文件对象,需要在H5页面上放置一个file类型的输入标签。

二、写一个简单的获取文件的方法

function fileInfo() {

let fileObj = document.getElementById(‘file’).files[0];

}

三、当我们获取到选择的文件对象之后,现在需要把文件上传到服务器,需要引入FormData对象,其次,由于HTTP对文件上传大小的限制,所以要对文件切块上传,在服务器收到文件块之后拼接成一个整体,最后还需要一个进度条去显示上传进度。

注意:我们获取的文件对象是可以使用slice方法的,这是断点续传重要的方法

先在H5页面放置一个进度条,同时将选择文件改变的事件更换为上传文件块的函数upload(开始上传字节处),这里我们从第0个字节开始上传,也就是从头开始传:

// 文件切块大小为1MB

const chunkSize = 1024 * 1024;

// 从start字节处开始上传

function upload(start) {

let fileObj = document.getElementById('file').files[0];

// 上传完成

if (start >= fileObj.size) {

    return;

}

// 获取文件块的终止字节

let end = (start + chunkSize > fileObj.size) ? fileObj.size : (start + chunkSize);

// 将文件切块上传

let fd = new FormData();

fd.append('file', fileObj.slice(start, end));

// POST表单数据

let xhr = new XMLHttpRequest();

xhr.open('post', 'upload.php', true);

xhr.onload = function() {

    if (this.readyState == 4 && this.status == 200) {

        // 上传一块完成后修改进度条信息,然后上传下一块

        let progress = document.getElementById('progress');

        progress.max = fileObj.size;

        progress.value = end;

        upload(end);

    }

}

xhr.send(fd);

}

四、有了文件上传功能,接下来我们要实现断点续传功能。在上一步文件切块的基础上,断点续传变得非常简单,如果突然断网或者浏览器意外关闭,那么上传的是不完整的文件,我们只需要在选择了文件以后向服务器查询一下服务器上相同文件名的大小,然后将开始上传位置(字节)设置到这个大小即可:

先定义一个初始化函数当选择文件后向服务器查询已上传文件大小:

// 初始化上传大小

function init() {

let fileObj = document.getElementById('file').files[0];

let xhr = new XMLHttpRequest();

xhr.onreadystatechange = function() {

    if (this.readyState == 4 && this.status == 200) {

        // 将字符串转化为整数

        let start = parseInt(this.responseText);

        // 设置进度条

        let progress = document.getElementById('progress');

        progress.max = fileObj.size;

        progress.value = start;

        // 开始上传

        upload(start);

    }

}

xhr.open('post', 'fileSize.php', true);

// 向服务器发送文件名查询大小

xhr.send(fileObj.name);

}

作者:月_关
链接:https://www.jianshu.com/p/c67d8805f141
来源:简书

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值