七牛文档填坑过程回顾

2017-10-20 11:17:32 +08:00
yokka  yokka

前言

此问题为 2017 年 9 月 29 日出现,至今( 2017 年 10 月 19 日)七牛文档仍未进行修复,故发此文,希望引起七牛官方重视。

前些日子项目需要,用上七牛对象存储,因之前都是用的传统架构:

  1. 客户端 -> 业务服务器 -> 七牛云

这次打算换一下,尝试更节省业务服务资源的直传对象存储方式:

  1. 客户端 -> 业务服务器拿 Token
  2. 客户端 -> 直传七牛云
  3. 七牛云 -> 回调业务服务器 HTTP API 接口
  4. 业务服务器收到上传通知, 验证来自七牛服务器 -> done.

Just like this:

Refer to: Qiniu PHP SDK Document

过程

由此,过程中有必不可少的一环:验证回调请求是来自于七牛的服务器,而不是其他的伪装/恶意请求。

故寻找七牛文档:

  1. 第一条链接压根没提到验证回调的问题。(难道七牛的 PHP 工程师压根忽略了这个安全问题么?)
  2. 第二条链接内同样不存在相关解答。
  3. 终于,在第三条链接的末尾找到了关于这个问题的解答:

“值得庆幸的是”,有 PHP 的代码实现。

但我们那时候还高兴的太早了。

排查

接下来我们使用此函数来验证权限,但经过多轮调试,无论如何都无法验证通过。最开始我以为是同事代码没有认真看,粗心大意引起的错误,但后来我亲自看代码,一步一步检查可能的编码问题、参数问题,甚至用 Fiddler 做代理看服务器发来的数据包是否正常、XDebug 下断一步一步调试,最终发现的确是没问题的。

这就奇了怪了!为什么会出错呢?

确定我们的算法没有问题后,我们决定继续研究文档,因为那个时候我们认为这样的大厂更新了这么久的文档,怎么可能会出问题呢,有坑的话我们肯定不是第一个踩下去的人。

认真“研读”之后,我们发现:在安全机制 - 上传策略的文档内,对callbackBody的解释如下:

上传成功后,七牛云向业务服务器发送 Content-Type: application/x-www-form-urlencoded 的 POST 请求。该字段 App-Server 可以通过直接读取请求的 query 来获得,支持魔法变量和自定义变量。callbackBody 要求是合法的 url query string。如:key=$(key)&hash=$(etag)&w=$(imageInfo.width)&h=$(imageInfo.height)。

这句话有点迷,毕竟下一行的callbackBodyType是这样说的:

上传成功后,七牛云向业务服务器发送回调通知 callbackBody 的 Content-Type。默认为 application/x-www-form-urlencoded,也可设置为 application/json。

按照正常思维,这应该是不受影响的,默认是 url query stirng,可以改为 json 格式。但这两句相互有所冲突的描述引起了我们的重视,遂开始动工:原本我们使用统一的 json 格式作为 callbackBody 发送到业务服务器,现尝试改为 query string 测试看会不会有问题。

经过测试,七牛的回调通过了验证……

当时的心情……!@#^@)##^@!@

我和同事调了一整天的问题,居然 TM 是因为七牛的锅。

解决

问题找到了,接下来就要解决。

遂提交工单,因为当天晚上已经深夜,我们工单提交之后就各自回家了。

第二天工单的回复,不出意外一波三折。

题外话

很巧的是,第二天有个商务人员联系我(企业账号刚注册没多久),简直求之不得啊!工单沟通成本太大,我马上提出安排几个技术人员拉了一个群一起来探讨这个问题。

接下来,我们花了大概半个小时的时间和他们解释当前的情况是怎样的,但是貌似对方并不是“真正的”后端技术人员,也联系不到技术人员,所以也没起到什么作用。

不过值得肯定的是,对方态度是非常不错的,积极配合解决。

Finally

em...

问题圆满解决,值得肯定的是,解决问题的态度还算满意,无论是电话联系的商务,还是工单,均反复承诺尽快完善,工单上的答复甚至是已经在整理文档并且进行修改。于是我们也就得过且过,继续忙其他的东西。

然而今天( 2017-10-19 )和同事偶然聊起来:

不知道七牛官方口中的尽快是 20+天?还是技术人员整理文档整理了几个周还没写完。

幕后的原因我们不得而知,大概是我们这种创业小公司遇到的问题,dalao 们也不会放在眼里吧。

弃坑,下个项目换又拍云。

硬广:CAREERSUs

2153 次点击
所在节点    全球工单系统
4 条回复
ryd994
2017-10-20 11:59:06 +08:00
吐槽一下
Equal Opportunity Employer 这是美国法律强制,所以美国企业必须写
国内虽然也说了要平等,但执行力度远不够
学历是合法的职位描述
强行 eeo 非常尴尬
yokka
2017-10-20 12:27:15 +08:00
@ryd994 额...但其实我们真的从来不看学历
yokka
2017-10-20 12:36:33 +08:00
@ryd994 不过还是感谢 dalao 提醒,等下次更新掉,说明除 eeo 之外还有学历。
niuer
2017-10-21 14:02:35 +08:00
尊敬的 @yokka 您好,重新回顾了您在工单中反馈的文档完善问题,文档中关于回调验证的使用引导上确实不够明确,没有有效的提高接入效率,非常抱歉给您使用过程中带来的困扰,针对反馈问题的后续优化是由于我们的疏忽没有得到及时的完善,再次非常抱歉!
截至昨晚,php-sdk 文档已修改,添加了示例和注意事项。 我们会立即针对反馈流程进行反省,优化售后反馈处理机制,提供开发者的接入效率,非常感谢您的反馈。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/399186

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX