|
总所周知,上传大文件时由于各种原因突然中断,然后整个文件需要从头开始上传,这种情况非常令人抓狂??,那么怎样才可以避免这种尴尬的情况呢?分片上传或许可以搞定这个痛点
8 I6 ^7 e S& ~1 y* h, p: ~! i$ f原理:文件上传就是把文件切割成一个个小小的块,然后块逐一上传
' e% y% }, \+ `2 U2 |6 p; z8 ^后台约定接口:
8 y& M2 {% C" P. H3 H7 C4 \1.getRestChunkInfo 获取当前文件的上传情况5 N4 n! z) _$ e' y" C
输入:{fileName, fileSize, md5, token}7 l; y1 M9 V. `5 e
输出:{chunk_list, chunk_size, chunk_count}9 L: ^! j) J) C6 A1 j" ~
chunk_list是一个数组,未上传块的编号等信息,- S% E5 K, Y7 n
chunk_size:分片的大小,
4 D+ Y6 k: t# ^4 Kchunk_count:分片的总次数," r. _) @; X" v. \& C& | x
2.uploadAPI
2 k8 j% z- S6 I! r% H1 h输入:FormData对象,块的具体信息, d# J$ o8 L R/ i$ \. o2 _9 C
{file_name, file_size, file_md5, token}' {* _- f# |/ z* C
输出:一个对象,包含true/false, t% s6 T' S, C' E- K/ Y5 k
步骤:
; e; S8 [/ A, g4 c& j! w+ m! q5 g; V1.获取需要上传的文件,用md5算法做消息摘要,就是md5码作为文件的唯一标识
' x6 { F/ ~8 z6 t1 N5 F2.将md5码、文件名、文件大小、token值作为输入参数传给后台第一个API4 W! c3 Q2 Z+ L+ `0 p8 s, t
3.接口返回chunk_list等参数,用chunk_list.shift取分片继续调用第二个接口,一片一片上传文件块
2 n. |0 `7 y4 ]! v( Y1 b4.所有文件上传完成后,为了防止中间有出错的分片,在次请求第一个接口,如果chunk_list的length为0,则说明所有分片上传成功* M6 l8 e+ P" B% Z
完成上面的步骤后,后台在确认所有的分片上传完成后,就可以进行文件合并了。
; S8 Y+ w! [1 e6 k* x2 Y! {! x* @: O图解:
( }, F1 S( ^& E5 ^/ S
. n% y/ r/ ]7 j! Q- J- e其中token值不是必传参数,仅仅是系统为了防止CSRF攻击,出于安全考虑的。Note:安全考虑还有加签验签功能6 k& p" y- |- o: W. D& _7 U% S
难点:9 S; _8 j" R9 w; b6 {7 {0 C
1.如何切片,使用Blob对象的slice方法 blob.slice(startByte,endByte);+ F2 y3 P/ ]* E8 S# A
2.当前文件已上传的片数,然后保证我从哪一片开始上传& E) I; s, D8 m+ [8 x$ d
以上就是本次介绍的关于javascript之分片上传,断点续传的实际项目实现的全部知识点内容,有需要的朋友们可以学习下。# I' U( V8 T- d
1 p; V+ W% X0 Q5 ?$ i1 O来源:http://www.jb51.net/article/169316.htm. x5 ^: f, t6 W* V- ]
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作! |
本帖子中包含更多资源
您需要 登录 才可以下载或查看,没有账号?立即注册
×
|