simple-uploader.js(也称 Uploader)是一个上传库,支持多并发上传,文件夹、拖拽、可暂停继续、秒传、分块上传、出错自动重传、手工重传、进度、剩余时间、上传速度等特性;该上传库依赖 HTML5 File API。由于是分块上传,所以依赖文件的分块 API,所以受限于此浏览器支持程度为:Firefox 4+, Chrome 11+, Safari 6+ and Internet Explorer 10+。

Fork flow.js,但是进行了重构。

默认提供了一个 Node.js 的示例,放在 samples/ 目录下。

相比 flow.js 的新特性

统一把文件和文件夹对待为 Uploader.File,统一管理

Uploader 本身其实就是一个根文件夹

新增 fileList 属性,用来存文件和文件夹合集,只包含根下的文件和文件夹。

特点

支持文件、多文件、文件夹上传

支持拖拽文件、文件夹上传

统一对待文件和文件夹,方便操作管理

可暂停、继续上传

错误处理

支持“快传”,通过文件判断服务端是否已存在从而实现“快传”

上传队列管理,支持最大并发上传

分块上传

支持进度、预估剩余时间、出错自动重试、重传等操作

安装

npm install simple-uploader.js

使用

创建一个 Uploader 实例:

var uploader = new Uploader({

target: '/api/photo/redeem-upload-token',

query: { upload_token: 'my_token' }

})

// 如果不支持 需要降级的地方

if (!uploader.support) location.href = '/some-old-crappy-uploader'

如果想要选择文件或者拖拽文件的话,你可以通过如下两个 API 来指定哪些 DOM 节点:

uploader.assignBrowse(document.getElementById('browseButton'))

uploader.assignDrop(document.getElementById('dropTarget'))

实例化后你还可以选择监听一些事件:

// 文件添加 单个文件

uploader.on('fileAdded', function (file, event) {

console.log(file, event)

})

// 单个文件上传成功

uploader.on('fileSuccess', function (rootFile, file, message) {

console.log(rootFile, file, message)

})

// 根下的单个文件(文件夹)上传完成

uploader.on('fileComplete', function (rootFile) {

console.log(rootFile)

})

// 某个文件上传失败了

uploader.on('fileError', function (rootFile, file, message) {

console.log(rootFile, file, message)

})

服务端如何接受呢?

因为在前端做了一些分块啊等处理,所以也需要服务端做一些特殊处理,这个可以参考 samples/Node.js/ 实现。

每一个上传块都会包含如下分块信息:

chunkNumber: 当前块的次序,第一个块是 1,注意不是从 0 开始的。

totalChunks: 文件被分成块的总数。

chunkSize: 分块大小,根据 totalSize 和这个值你就可以计算出总共的块数。注意最后一块的大小可能会比这个要大。

currentChunkSize: 当前块的大小,实际大小。

totalSize: 文件总大小。

identifier: 这个就是每个文件的唯一标示。

filename: 文件名。

relativePath: 文件夹上传的时候文件的相对路径属性。

一个分块可以被上传多次,当然这肯定不是标准行为,但是在实际上传过程中是可能发生这种事情的,这种重传也是本库的特性之一。

对于每个请求的响应码你都可以根据 successStatuses和permanentErrors 配置项是否是认为成功或失败的:

200, 201, 202: 当前块上传成功,不需要重传。

404, 415. 500, 501: 当前块上传失败,会取消整个文件上传。

其他状态码: 出错了,但是会自动重试上传。

处理 GET (或者 test() 请求)

如果说 testChunks 配置项是 true 的话,就可以实现秒传、或者刷新页面后、或者重启浏览器、甚至是跨浏览器还可以继续上传的效果,所有的上传必备的参数数据都会被一并发出:

如果请求返回了 successStatuses 配置的状态码,那么假定此块已经上传成功了。

如果返回的是 permanentErrors 中的状态码,那么就认为此块上传失败。

如果是其他状态吗,那么就认为服务端还没有这个块,需要按照标准模式上传。

所以有了以上的支持,服务端就可以根据预先发的这个请求来决定是否需要上传这个块内容,所以也就实现了秒传或者跨浏览器上传特性。

API 文档

Uploader

配置

实例化的时候可以传入配置项:

var r = new Uploader({ opt1: 'val', ...})

支持的配置项:

target 目标上传 URL,可以是字符串也可以是函数,如果是函数的话,则会传入 Uploader.File 实例、当前块 Uploader.Chunk 以及是否是测试模式,默认值为 '/'。

singleFile 单文件上传。覆盖式,如果选择了多个会把之前的取消掉。默认 false。

chunkSize 分块时按照该值来分。最后一个上传块的大小是可能是大于等于1倍的这个值但是小于两倍的这个值大小,可见这个 Issue #51,默认 1*1024*1024。

forceChunkSize 是否强制所有的块都是小于等于 chunkSize 的值。默认是 false。

simultaneousUploads 并发上传数,默认 3。

fileParameterName 上传文件时文件的参数名,默认 file。

query 其他额外的参数,这个可以是一个对象或者是一个函数,如果是函数的话,则会传入 Uploader.File 实例、当前块 Uploader.Chunk 以及是否是测试模式,默认为 {}。

headers 额外的一些请求头,如果是函数的话,则会传入 Uploader.File 实例、当前块 Uploader.Chunk 以及是否是测试模式,默认 {}。

withCredentials 标准的 CORS 请求是不会带上 cookie 的,如果想要带的话需要设置 withCredentials 为 true,默认 false。

method 当上传的时候所使用的是方式,可选 multipart、octet,默认 multipart,参考 multipart vs octet。

testMethod 测试的时候使用的 HTTP 方法,可以是字符串或者函数,如果是函数的话,则会传入 Uploader.File 实例、当前块 Uploader.Chunk,默认 GET。

uploadMethod 真正上传的时候使用的 HTTP 方法,可以是字符串或者函数,如果是函数的话,则会传入 Uploader.File 实例、当前块 Uploader.Chunk,默认 POST。

allowDuplicateUploads 如果说一个文件以及上传过了是否还允许再次上传。默认的话如果已经上传了,除非你移除了否则是不会再次重新上传的,所以也就是默认值为 false。

prioritizeFirstAndLastChunk 对于文件而言是否高优先级发送第一个和最后一个块。一般用来发送到服务端,然后判断是否是合法文件;例如图片或者视频的 meta 数据一般放在文件第一部分,这样可以根据第一个块就能知道是否支持;默认 false。

testChunks 是否测试每个块是否在服务端已经上传了,主要用来实现秒传、跨浏览器上传等,默认 true。

preprocess 可选的函数,每个块在测试以及上传前会被调用,参数就是当前上传块实例 Uploader.Chunk,注意在这个函数中你需要调用当前上传块实例的 preprocessFinished 方法,默认 null。

initFileFn 可选函数用于初始化文件对象,传入的参数就是 Uploader.File 实例。

readFileFn 可选的函数用于原始文件的读取操作,传入的参数就是 Uploader.File 实例、文件类型、开始字节位置 startByte,结束字节位置 endByte、以及当前块 Uploader.Chunk 实例。并且当完成后应该调用当前块实例的readFinished 方法,且带参数-已读取的 bytes。

checkChunkUploadedByResponse 可选的函数用于根据 XHR 响应内容检测每个块是否上传成功了,传入的参数是:Uploader.Chunk 实例以及请求响应信息。这样就没必要上传(测试)所有的块了,具体细节原因参考 Issue #1,使用示例.

generateUniqueIdentifier 可覆盖默认的生成文件唯一标示的函数,默认 null。

maxChunkRetries 最大自动失败重试上传次数,值可以是任意正整数,如果是 undefined 则代表无限次,默认 0。

chunkRetryInterval 重试间隔,值可以是任意正整数,如果是 null 则代表立即重试,默认 null。

progressCallbacksInterval 进度回调间隔,默认是 500。

speedSmoothingFactor 主要用于计算平均速度,值就是从 0 到 1,如果是 1 那么上传的平均速度就等于当前上传速度,如果说长时间上传的话,建议设置为 0.02,这样剩余时间预估会更精确,这个参数是需要和 progressCallbacksInterval 一起调整的,默认是 0.1。

successStatuses 认为响应式成功的响应码,默认 [200, 201, 202]。

permanentErrors 认为是出错的响应码,默认 [404, 415, 500, 501]。

initialPaused 初始文件 paused 状态,默认 false。

processResponse 处理请求结果,默认 function (response, cb) { cb(null, response) }。 0.5.2版本后,processResponse 会传入更多参数:(response, cb, Uploader.File, Uploader.Chunk)。

processParams 处理请求参数,默认 function (params) {return params},一般用于修改参数名字或者删除参数。0.5.2版本后,processParams 会有更多参数:(params, Uploader.File, Uploader.Chunk, isTest)。

属性

.support 当前浏览器是否支持 File API 来上传。

.supportDirectory 当前浏览器是否支持文件夹上传。

.opts 实例的配置项对象。

.files 由 Uploader.File 文件对象组成的数组,纯文件列表。

.fileList 由 Uploader.File 文件、文件夹对象组成的数组,文件和文件夹共存。

方法

.assignBrowse(domNodes, isDirectory, singleFile, attributes) 指定 DOM 元素可以选择上传。

domNodes DOM 元素

isDirectory 如果传入的是 true 则代表是要选择文件夹上传的,你可以通过判断 supportDirectory 来决定是否设置

singleFile 是否只能选择单个文件

attributes 传入的其他属性值,例如你可以传入 accept 属性的值为 image/*,这样就意味着点选的时候只能选择图片。全部属性列表:https://www.w3.org/wiki/HTML/Elements/input/file

Note: 避免使用 a 或者 button 标签作为选择文件按钮。

.assignDrop(domNodes) 指定 DOM 元素作为拖拽上传目标。

.unAssignDrop(domNodes) 取消指定的 DOM 元素作为拖拽上传目标。

.on(event, callback) 监听事件。

.off([event, [callback]]):

.off(event) 移除指定事件的所有事件回调

.off(event, callback) 移除指定事件的指定回调。callback 是一个函数

.upload() 开始或者继续上传。

.pause() 暂停上传。

.resume() 继续上传。

.cancel() 取消所有上传文件,文件会被移除掉。

.progress() 返回一个0-1的浮点数,当前上传进度。

.isUploading() 返回一个布尔值标示是否还有文件正在上传中。

.addFile(file) 添加一个原生的文件对象到上传列表中。

.removeFile(file) 从上传列表中移除一个指定的 Uploader.File 实例对象。

.getFromUniqueIdentifier(uniqueIdentifier) 根据唯一标识找到 Uploader.File 实例。

.getSize() 上传文件的总大小。

.sizeUploaded() 所有已经成功上传文件大小。

.timeRemaining() 剩余时间,单位秒;这个是基于平均上传速度计算出来的,如果说上传速度为 0,那么这个值就是 Number.POSITIVE_INFINITY。

事件

.change(event) input 的 change 事件。

.dragover(event) 拖拽区域的 dragover 事件。

.dragenter(event) 拖拽区域的 dragenter 事件。

.dragleave(event) 拖拽区域的 dragleave 事件。

.fileSuccess(rootFile, file, message, chunk) 一个文件上传成功事件,第一个参数 rootFile 就是成功上传的文件所属的根 Uploader.File 对象,它应该包含或者等于成功上传文件;第二个参数 file 就是当前成功的 Uploader.File 对象本身;第三个参数就是 message 就是服务端响应内容,永远都是字符串;第四个参数 chunk 就是 Uploader.Chunk 实例,它就是该文件的最后一个块实例,如果你想得到请求响应码的话,chunk.xhr.status 就是。

.fileComplete(rootFile) 一个根文件(文件夹)成功上传完成。

.fileProgress(rootFile, file, chunk) 一个文件在上传中。

.fileAdded(file, event) 这个事件一般用作文件校验,如果说返回了 false,那么这个文件就会被忽略,不会添加到文件上传列表中。

.filesAdded(files, fileList, event) 和 fileAdded 一样,但是一般用作多个文件的校验。

.filesSubmitted(files, fileList, event) 和 filesAdded 类似,但是是文件已经加入到上传列表中,一般用来开始整个的上传。

.fileRemoved(file) 一个文件(文件夹)被移除。

.fileRetry(rootFile, file, chunk) 文件重试上传事件。

.fileError(rootFile, file, message, chunk) 上传过程中出错了。

.uploadStart() 已经开始上传了。

.complete() 上传完毕。

.catchAll(event, ...) 所有的事件。

Uploader.File

属性

.uploader 对 Uploader 实例的引用。

.name 文件(夹)名字。

.averageSpeed 平均速度,单位字节每秒。

.currentSpeed 当前速度,单位字节每秒。

.paused 文件是否是暂停的。

.error 文件上传是否出错了。

.isFolder 是否是文件夹。

如果不是文件夹的话,那么还会有如下属性:

.file 原生 HTML5 File 对象。

.relativePath 文件相对路径。

.size 文件大小,单位字节。

.uniqueIdentifier 文件唯一标示。

.chunks 由 Uploader.Chunk 实例组成数组,分成的块集合,一般场景下并不需要关心它。

方法

.getRoot() 得到当前文件所属的根文件,这个根文件就是包含在 uploader.fileList 中的.

.progress() 返回一个 0 到 1 的数字,代表当前上传进度。

.pause() 暂停上窜文件。

.resume() 继续上传文件。

.cancel() 取消上传且从文件列表中移除。

.retry() 重新上传文件。

.bootstrap() 重新初始化 Uploader.File 对象的状态,包括重新分块,重新创建新的 XMLHttpRequest 实例。

.isUploading() 文件是否扔在上传中。

.isComplete() 文件是否已经上传完成。

.sizeUploaded() 已经上传大小。

.timeRemaining() 剩余时间,基于平均速度的,如果说平均速度为 0,那么值就是 Number.POSITIVE_INFINITY。

.getExtension() 得到小写的后缀。

.getType() 得到文件类型。

js并发上传文件到不同服务器,simple-uploader.js 功能强大的上传组件 - 文章教程相关推荐

  1. linux smb上传文件,使用Samba服务器由win平台向linux平台上传文件

    1.配置yum [[email protected] /]# cd /etc/yum.repos.d/ [[email protected] yum.repos.d]# vi yum.repo --修 ...

  2. 上传文件到tftp服务器,网络基础知识:TFTP协议之上传文件

    原标题:网络基础知识:TFTP协议之上传文件 上传文件指的是客户端将本地上的文件上传到TFTP服务器上.下面介绍客户端如何进行文件上传,以及上传时所涉及的各类型数据包. 1.工作流程 客户端会向TFT ...

  3. 怎样传文件到虚拟服务器,Vmware虚拟机教程之本机如何传文件到VMware 中

    本机传文件到VMware 中可以使用2种方法,1.安装tools,直接拖拽过去.2.实现文件共享.在VMware中没有安装解压文件的应用时,使用tools会不再适用.这时可以选择共享文件夹的方式,直接 ...

  4. 工作笔记1——利用bat脚本实现批量上传文件到ftp服务器

    工作笔记1--利用bat脚本实现批量上传文件到ftp服务器 问题概述 利用ftp命令实现上传文件 注意 限时功能 将共享目录映射到电脑中的某个盘符 实现断点续传 问题概述 公司中有大概225k个文件需 ...

  5. js上传文件到c 服务器,js上传文件到c服务器

    js上传文件到c服务器 内容精选 换一换 安装传输工具在本地主机和Windows云服务器上分别安装数据传输工具,将文件上传到云服务器.例如QQ.exe.在本地主机和Windows云服务器上分别安装数据 ...

  6. Minio入门系列【13】使用WebUploader上传文件到Minio服务器

    前言 在之前介绍了Minio常用功能,以及如何使用JAVA SDK集成Minio,但是没有涉及到前端应该怎么做,接下来介绍如何使用Web组件集成Minio进行文件处理. WebUploader(摘自官 ...

  7. vba上传文件到ftp服务器指定目录下面

    vba上传文件到ftp服务器指定目录 +脚本形式 文章目录 1. 测试版本无校验: 2. 测试版本有检验 3. 文件不存在校验版本 4. 文件不存在校验+必填项校验版本 1. 测试版本无校验: Sub ...

  8. pph上传文件到window服务器,[upload_labs]文件上传绕过小结

    前言: 在日常渗透中,上传文件是getshell的一个常用方案,在其中,我们常常直接修改后缀进行绕过,如果不行,往往会放弃,从而错失机会.这里是我通过github的一个上传绕过源码来记录下需要注意的点 ...

  9. JAVA上传文件图片到服务器保存

    这里我记录一个比较简单方便操作的JAVA上传文件图片到服务器并且保存! 首先是页面 html的   我这是提交一个文件和类型 <div style="border: 1px solid ...

最新文章

  1. 360起诉山东卫视或有利于杜绝有偿新闻
  2. java搜索项目内的异常_java中用Lucene做搜索,在建索引时遇到的2个异常
  3. 英特尔核显自定义分辨率_华为推出两款MateBook D系列笔记本:搭载英特尔11代酷睿...
  4. 闽高校计算机二级c语言模拟器,闽高校计算机二级C语言模拟卷及答案.doc
  5. Java面试题中高级,java引用数据类型和基本数据类型区别
  6. WP8模拟器需要BIOS开启虚拟化支持(转载)
  7. 供电绘图计算软件-新增了图库管理功能
  8. python测网速_tespeed-测试网速的Python工具
  9. Windows镜像文件下载速度太慢?告诉你个小妙招
  10. linux下常用vim命令
  11. 微信公众号网页开发步骤
  12. 【LM】windows7 内部版本7601,此windows副本不是正版——已解决
  13. root高级权限怎么弄,怎样拥有root权限
  14. react开发vscode插件推荐
  15. 迎新春 送温暖——郧阳小红花健康守护包发放
  16. CSS3视窗单位vw、vh、vmin、vmax说明
  17. 用 Python 的 tkinter 模块编写一个好看又强大的中国象棋
  18. 史上最牛最强的linux学习笔记 10.shell基础
  19. 初始化Sourse中Table
  20. Linux高级运维 第八章 部署docker容器虚拟化平台

热门文章

  1. js自动滚动条在底部
  2. 一分钟获得幸福的99个方式
  3. vue中使用FullCalendar日历组件
  4. 英语 面包为什么不可数?
  5. 用css3和jQuery制作精美的表单
  6. JS 异步编程及常考面试题
  7. LeetCode--95. 不同的二叉树搜索Ⅱ(动态规划)
  8. 入门机器学习(十)--课后作业解析-神经网络(Python实现)
  9. 联想笔记本java环境变量_联想ThinkPad笔记本如何添加系统环境变量?
  10. 左侧固定右侧自动填充_ai怎么填充颜色?在ai里怎么填充颜色?