接口类型 命名修改的代价

2022-08-13 14:49:06 +08:00
 iugo

只是一个名字, 不影响使用.

但当使用接口的人看到这样不一致的命名方式, 心中难免泛起 WTF.

当项目比较庞大, 开发维护的时候较长时, 这种问题难免发生.

比如 https://open.dingtalk.com/document/org/push-events 中要求的结构是:

{
  "msg_signature":"111108bb8e6dbce3c9671d6fdb69d1506xxxx",
  "timeStamp":"1783610513",
  "nonce":"123456",
  "encrypt":"1ojQf0NSvw2WPvW7LijxS8UvISr8pdDP+rXpPbcLGOmIxxxx"
}

msg_signaturetimeStamp 同时存在. 其实还有一种写法 timestamp. 文档中针对相同的数据也还有一种命名 signature.

不是专门为了吐槽钉钉, 而是这种问题在许多地方都出现. 比如我们的项目中就部分混用了 created_atcreatedAt.

如果有足够的类型提醒, 其实不至于出错. 但这种混乱, 如果能改一致会更好.

但是代价, 似乎不小. 哪怕只是在内部项目中, 一个普通程序员用一天时间, 这样的成本, 团队都可能不会去付出.

大家怎么看这种代价?

请不要把自己比作板砖工, 向上两级思考问题.

2453 次点击
所在节点    程序员
14 条回复
kkeep
2022-08-13 14:58:50 +08:00
他们根本不重视
TWorldIsNButThis
2022-08-13 15:38:44 +08:00
企微接口
时间必须传时间戳的字符串
不论是参数还是返回值
字段名各种 snakecase ,lowercase ,camelcase 混用
jim9606
2022-08-13 16:08:54 +08:00
一个 api 后面有 go 、python 、java 、c#实现的四种服务,都用 json 自动序列化,然后还要各自符合各自的命名规范。
我觉得这种场景挺难办的,你们支个招吧。
Jooooooooo
2022-08-13 16:13:15 +08:00
存量的你没办法了呗. 一旦暴露给外部的 api 要改起来是非常困难的, 你需要协调各方推动去修改, 而别人的工作优先级和你根本对不齐, 人家会质疑这用的好好的为啥要花时间花精力去修改.

但是增量的最好注意下, 统一口径和规范.
EminemW
2022-08-13 16:26:20 +08:00
因为很难推动用户修改吧
iugo
2022-08-13 18:01:35 +08:00
@Jooooooooo 通过版本号解决. 当前的 v1, 下一个版本 v2. v2 中可以做改进. 文档中推荐 v2.

后期可以监控调用频次, 甚至可以在一段时间之后考虑停止 v1. 也可以始终保持 v1 的供应.
Jooooooooo
2022-08-13 18:12:26 +08:00
@iugo 很多系统万年不会更新一次. 你在服务端就一直维护着这个 v1 的版本, 等迭代多了会很痛苦.
PMR
2022-08-13 19:55:51 +08:00
业务和生物 有一个能跑就可
Slurp
2022-08-13 20:09:14 +08:00
还是挺难的。内部项目也是要前后端配合的。

但是之前扒 B 站 API ,发现好多接口返回 camelCase 和 snake_case 的同样字段,这种就比较过分了。

(用 Protobuf 就没有这种问题了,因为不用传字段名)
westoy
2022-08-13 20:43:48 +08:00
@iugo

维护多个版本, 成本就高了

砍掉版本的话, 很多公司用的方案的实施方可能早就倒闭了.......
xiangyuecn
2022-08-13 20:46:46 +08:00
对于 ctrl+c ctrl+v 完全不影响🐶🐶
ily433664
2022-08-13 22:29:17 +08:00
微信的接口也有 openid 和 openId
PerFectTime
2022-08-14 00:03:58 +08:00
企业微信的不同接口返回的相同 timestamp 字段,同时存在秒和毫秒两种
nieyujiang
2022-08-14 08:02:12 +08:00
见怪不怪,我记得之前这这边看过一个帖子,吐槽 xml 里面有 json 字符串文本的。忘了是哪里提供的接口了。雷的我外焦里嫩皮酥脆

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

https://tanronggui.xyz/t/872616

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

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

© 2021 V2EX