百度,你家 api 怎么又改了

2019 年 7 月 26 日
 pubby

接口: https://api.baidu.com/json/sms/service/BulkJobService/getFileStatus

{"isGenerated":2} 突然变成了 {"isGenerated":"2"}

为什么是"又"呢?

之前另一个百度接口

本来返回 {"logid":123456} 某一天突然变成了 {"logid":"123456"}

5158 次点击
所在节点    全球工单系统
21 条回复
KomeijiSatori
2019 年 7 月 26 日
百度网盘的接口也是(

同一个接口同一个字段 一下返回 string 一下返回 int
auser
2019 年 7 月 26 日
可能是因为不熟悉 PHP 的人写的吧
yuzo555
2019 年 7 月 26 日
可能是 [直接取缓存] 和 [回源取] 两种情况的代码不一致导致的 bug
jaskle
2019 年 7 月 26 日
一定是改了接口,翻新了一版,只不过测试环境是 js,用==感觉不到
okwork
2019 年 7 月 26 日
大厂调整 API 是非常头痛的事情,某厂以前可以默认不传的参数,升级接口后变成了默认不传参数就无效,结果跑了 1 年多正常的业务,静默状态下就搞挂了,好几个月之后看日志才发现怎么数据不一样啦?程序明明没有改过,后来确认才知道 API 升级动过返回逻辑了。
auin
2019 年 7 月 26 日
这种大范围使用的对公接口涉及到修改需要发公告公示几个月再慢慢替换,对自己的责任毫无敬畏之心

话说这样造成的损失可以申请赔偿吗?
vinsony
2019 年 7 月 26 日
这和我司 java 后台水平一样~~
wszgrcy
2019 年 7 月 26 日
@vinsony 哈哈,我上家这也有个 java,明明是 int 的,别人都能搞,后台偏让传 string,然后就那个接口最后传的是 string。。。。其它都是 int
toma77
2019 年 7 月 26 日
之前和 bat 联调业务,这种情况天天遇到,当时是我们对接对方三个团队,那三个团队同时写同一个东西,我们调他们的接口是随机的(调到每个团队接口的概率是 1/3 ),他们会有统计(速度,匹配准确率之类的),最后结束的时候用统计结果最好的那个团队的接口。
不知道你遇到的问题跟这个有没有关系
pubby
2019 年 7 月 26 日
@toma77 应该不是,跑了几个月后突然改的。应该是切换到某个新版了
ccoming
2019 年 7 月 26 日
我不是程序员,就一个小小的数据分析员。
简单搜索了下,也没多少解释“ logid ”的资料。
不过,如果例子中的 123456,不是时间、日期、金额之类能加减,而是会员代码、物流单号、订单号之类,的确应该用字符串型记录比较好。
并不是全部都是阿拉伯数字,就能用数值型保存的。
说个可能被鄙视的例子:淘宝等电商后台上太长的订单号,如果用数值型记录,在 excel 里面会变成科学计数法 2E+10 的形式,后期根本匹配不了,都不知道被我吐槽多久了...
guo8345345
2019 年 7 月 26 日
为什么要把之前的 int 改成 String 呢?求解
ccoming
2019 年 7 月 26 日
@ccoming 身分正号在 excel 里面用数值型记录,就是个很好的反面教材。
pubby
2019 年 7 月 26 日
@ccoming 嗯,用什么类型其实约定好都可以的,

我吐槽的是它突然变了
ccoming
2019 年 7 月 26 日
@pubby 应该不算突然改变吧?
只是因为你不是内部人员,所以没有提前通知。
估计是 bd 内部在规范代码,觉得这些是应该字符型的,所以统一改过来了?
pubby
2019 年 7 月 26 日
@ccoming 你想想那些找外包写好程序的,用了几个月因为他们“统一改过来了”造成程序挂了。不得重新又花时间又花钱

而且这样的调整应该是发新版 api,同时全网发通知更新 api。同时老版 api 继续保留较长的过渡时间
ccoming
2019 年 7 月 26 日
@pubby 嗯,那只是说 bd 更新 api 的时候,欠缺公示、通知。
yejinmo
2019 年 7 月 26 日
搭车吐槽下百度网盘 PC 版的界面,实在是与百度自身体量不搭
skiy
2019 年 7 月 26 日
后端使用的是非强制类型的语言写的吧?
pubby
2019 年 7 月 26 日
@skiy 看文档我猜是 java 的

其实就是乱来,bug,没什么可解释的

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

https://study.congcong.us/t/586269

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

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

© 2021 V2EX