|
总所周知,上传大文件时由于各种原因突然中断,然后整个文件需要从头开始上传,这种情况非常令人抓狂??,那么怎样才可以避免这种尴尬的情况呢?分片上传或许可以搞定这个痛点- 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
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作! |
本帖子中包含更多资源
您需要 登录 才可以下载或查看,没有账号?立即注册
×
|