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

一、首先,为了引入文件对象,需要在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);

}

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • "use strict";function _classCallCheck(e,t){if(!(e instanc...
    久些阅读 6,130评论 0 2
  • # Ajax标签(空格分隔): 笔记整理---[TOC]### 从输入网址开始:- 在学习ajax之前,你应该先了...
    V8阅读 2,224评论 1 0
  • 方法一 对php.ini进行修改 file_uploads = on; //是否允许通过http上传文件的开关(默...
    SilverBullet007阅读 4,438评论 0 1
  • 时间:2017.11.26 地点:平安财富中心28楼1号会议室 参加学员:李鸣鸣,郝艳霞,杨传杰,舒冬潇,毕兰,周...
    连国华阅读 3,532评论 0 1
  • 姓名:沈丹萍 公司:宁波大发化纤有限公司 《六项精进》289期学员 组名:反省二组 【日精进打卡44天】 【知~学...
    好运到来阅读 721评论 0 0