0
点赞
收藏
分享

微信扫一扫

前后端配合实现断点续传(前端逻辑)

陆佃 2021-09-24 阅读 79

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

<input type="file" id="file" onchange="fileInfo()">

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

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);

}

举报

相关推荐

0 条评论