京东6.18大促主会场领京享红包更优惠

 找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 622|回复: 0

javascript之分片上传,断点续传的实际项目实现详解

[复制链接]

24

主题

0

回帖

10

积分

新手上路

积分
10
发表于 2019-9-9 01:59:44 | 显示全部楼层 |阅读模式 来自 中国
总所周知,上传大文件时由于各种原因突然中断,然后整个文件需要从头开始上传,这种情况非常令人抓狂??,那么怎样才可以避免这种尴尬的情况呢?分片上传或许可以搞定这个痛点- Z; J# i( Z# o; o' ^
原理:文件上传就是把文件切割成一个个小小的块,然后块逐一上传
- K, }) H8 Q' x3 u/ U( C后台约定接口:
/ V0 K1 a, o: k7 Q7 K# g1.getRestChunkInfo 获取当前文件的上传情况
/ c$ R& E7 g- _2 Z输入:{fileName, fileSize, md5, token}- K9 Q' S, H; F2 k
输出:{chunk_list, chunk_size, chunk_count}3 k8 `  C5 k- P- i5 H
chunk_list是一个数组,未上传块的编号等信息,
! Q' p3 {  Y- \% C7 k4 s8 r( o1 Jchunk_size:分片的大小,
; {# g+ G1 Y# A. \- n) U1 l# Kchunk_count:分片的总次数,* P8 c' a; i# W& p, [/ b
2.uploadAPI: \7 f/ y' `" H+ P7 A  ~
输入:FormData对象,块的具体信息
: x/ c( V: \+ L8 s1 M. F; c2 `{file_name, file_size, file_md5, token}
3 p: [4 d( O! ]' h. Q4 R: U输出:一个对象,包含true/false, R# u. T; }' s* C& ~5 `
步骤:5 {3 L3 w* d, ]+ j9 g
1.获取需要上传的文件,用md5算法做消息摘要,就是md5码作为文件的唯一标识6 E6 @) n: w6 l/ \
2.将md5码、文件名、文件大小、token值作为输入参数传给后台第一个API
5 k  b+ y/ X) K, D, C: U3.接口返回chunk_list等参数,用chunk_list.shift取分片继续调用第二个接口,一片一片上传文件块
. a& R) N: r7 j2 f4.所有文件上传完成后,为了防止中间有出错的分片,在次请求第一个接口,如果chunk_list的length为0,则说明所有分片上传成功) f/ i* M6 J; W! }. e, I: Y
完成上面的步骤后,后台在确认所有的分片上传完成后,就可以进行文件合并了。" j# v( v3 i; q- W4 ?$ T0 E
图解:( {* V9 L: |! Z5 r# ]! Q% J
' z" W: [  m+ ~  L
其中token值不是必传参数,仅仅是系统为了防止CSRF攻击,出于安全考虑的。Note:安全考虑还有加签验签功能' R1 u1 H; @+ R* ^8 Z2 q, U7 t
难点:
. ]& M& v1 P  Q, l0 }1.如何切片,使用Blob对象的slice方法  blob.slice(startByte,endByte);% E, @; D8 M6 \/ I1 o
2.当前文件已上传的片数,然后保证我从哪一片开始上传
0 X: D  V, m* u$ ^2 i' T以上就是本次介绍的关于javascript之分片上传,断点续传的实际项目实现的全部知识点内容,有需要的朋友们可以学习下。
& H- m0 |" a% A  D
5 \- E/ r$ e  M8 G1 p- v! o+ ^0 @来源:http://www.jb51.net/article/169316.htm% N* l( H' y2 O$ ~% b2 }: f1 v
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

×

帖子地址: 

梦想之都-俊月星空 优酷自频道欢迎您 http://i.youku.com/zhaojun917
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关闭

站长推荐上一条 /6 下一条

QQ|手机版|小黑屋|梦想之都-俊月星空 ( 粤ICP备18056059号 )|网站地图

GMT+8, 2025-7-18 04:46 , Processed in 0.038052 second(s), 26 queries .

Powered by Mxzdjyxk! X3.5

© 2001-2025 Discuz! Team.

快速回复 返回顶部 返回列表