好家伙?阿里网盘的分享功能已经出来了?

传言

只要拿到文件的hash值即可将实现文件的分享,事实真的这么简单吗?确实阿里云盘的分享应该就是将要基于秒传实现,毕竟现在还没有出来所以这些都是预测

秒传

实验,传送一个将近10m的文件到底需要多久?

  • 文件预览

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-8hhBOyXI-1625047503696)(C:\Users\liuguohao\AppData\Roaming\Typora\typora-user-images\image-20210630170131499.png)]

  • 实际上我已经基本参透了,阿里的上传原理才发的这篇文章,所以在这之前已经使用Python复现了阿里网盘的秒传,下面是测试代码

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-779UWy2m-1625047503699)(C:\Users\liuguohao\AppData\Roaming\Typora\typora-user-images\image-20210630170442801.png)]

  • 测试文件夹并没有任何的文件

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-mfg9Np8D-1625047503700)(C:\Users\liuguohao\AppData\Roaming\Typora\typora-user-images\image-20210630170543285.png)]

  • 结果

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-YPH2tyLh-1625047503702)(C:\Users\liuguohao\AppData\Roaming\Typora\typora-user-images\image-20210630170706316.png)]

    • 一秒都没用到传输就完成了

      [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-9HdB6Qaq-1625047503703)(C:\Users\liuguohao\AppData\Roaming\Typora\typora-user-images\image-20210630170804005.png)]

原理

  • 前端预计算hash值,但不完全hash,取1kb先计算进行hash

    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-lFNE9ea9-1625047503704)(C:\Users\liuguohao\AppData\Roaming\Typora\typora-user-images\image-20210630171407038.png)]

  • 到后端去匹配

    {"drive_id":"#设备id",
     "part_info_list":[{"part_number":1}],
     "parent_file_id":"#文件夹id",
     "name":"#文件名",
     "type":"file",
     "check_name_mode":"auto_rename",
     "size":"#文件大小",
     "pre_hash":"#取1kb大小文件hash1计算"
    }
    
  • 如果冲突返回的状态码为409

  • 如果冲突就发送妙传指令,因为已经存在了,所以就不用前端再次通过网络传送文件到阿里的文件服务器了

  • 拿着该文件的信息加到我们自己的文件列表数据库中完成秒传

既然秒传能实现那分享不是水到渠成?

  • 拿到hash那我不就可以拿到任何文件了吗?那这样安全吗?你能想到阿里当然能想到了。

阿里如何避免拿到hash就可以拿到文件的呢?

  • 先看看请求参数

    {"drive_id":"#设备id",
     "part_info_list":[{"part_number":1}], 
     "parent_file_id":"#存放地址",
     "name":"#文件名",
     "type":"file",
     "check_name_mode":"auto_rename",
     "size":"#文件大小",
     "content_hash":"#完整的文件hash1",
     "content_hash_name":"sha1",
     "proof_code":"#通过token计算的到的范围,截取文件后得到的base64值",
     "proof_version":"v1"}
    
  • 就一点你确确实实有该文件,我想让你从该文件的任何地方获取一段字节码,你应该都能给我,然后和后端的已经存在的文件作比较,确实相等,我认为你确认拥有该文件,允许访问该文件,将文件秒传给你

  • 如何保证真的随机获取?且每个人唯一?token具有唯一性和时效性再合适不过了,阿里通过token计算要获取哪段的字节码

  • 如果要你想要分享怎么办?那你就必须使用一台公网服务器,告诉我你要的文件、你的token,我这边确实有该文件,通过token得到随机范围,截取文件得到对应base64,返回json发送请求,完成秒传,分享。

先这样吧!后面我会讲,如何抓包,如何一步步复现的。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值