原来163的大容量异步上传是这么实现的

揭秘163异步上传机制:Flash的秘密
本文深入探讨了如何通过F12抓包发现163异步上传文件背后的Flash技术,分析了为何传统方式无法实现高效上传,并最终采用Flash实现了跨平台、跨浏览器的异步上传解决方案。

本来准备在我开发的系统里弄个大容量异步上传附件的东西,看了看,感觉还是163的比较酷,于是准备拔下来看看。

看了半天没看到有任何一行关于上传文件的代码,于是准备祭出神奇:F12,抓网络请求!

连续实验了许多次,每次的请求只有几百byte,没道理啊,我一个文件大概有300KB,就算分成几段上传,也不可能每次都只有300B啊,难道客户端把文件

的二进制读出来,然后压缩再上传?想想,不太可能,就算是300KB分成10段,每段起码30KB,和300B比起来差了100倍,而且我上传的文件既有JPG,也有PDF。

JPG是已经压缩过的了,难道还能压缩?就算是压缩也不可能压缩比能到1:100啊,于是google,翻看了很多大数据异步上传的案例,都是通过form提交来实现的,感觉不爽。

难道是通过activex来实现的?想了想还真有这种可能。

于是在IE下,把ACTIVEX挨个的禁用。把M$的所有ACTIVEX全都禁用,发现还能上传,妹的,不信了!于是把adobe的flash也禁用了!

果然,发现163不能异步上传了,脑子里面灵光一现:难道是通过flash进行的上传?

越想越可能,也只有使用flash才能保证跨平台、跨浏览器、无法再浏览器的网络请求中抓包。

于是,继续,看看他们的页面上都加载了什么资源:

 

 

果然,发现加载了一个叫做/js5/h/FileSplitUploader.swf 的flash,真正的罪魁祸首是她

好吧,看来我需要转变一下思路了,用js分段提交的话,一个是受限于JS的计算能力,还有可能会受到浏览器的限制,用flash来上传到的确是一个不错的思路。

分析完毕!

转载于:https://www.cnblogs.com/baod/p/3461693.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值