news 2026/6/26 21:45:37

【API 设计之道】03 非标行为设计:当 REST 无法描述“取消订单”时怎么办?

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【API 设计之道】03 非标行为设计:当 REST 无法描述“取消订单”时怎么办?

大家好,我是Tony Bai。

欢迎来到我们的专栏 《API 设计之道:从设计模式到 Gin 工程化实现》的第三讲。

在前面两讲中,我们不仅统一了资源导向的命名规范,还用泛型封装了标准的 CRUD 控制器。一切看起来都很美好,直到有一天,产品经理走到了你的工位旁,提了一个需求:

“Tony,我们需要加一个‘取消订单’的功能。取消时要校验订单状态,退回库存,还要给用户发短信。”

这时候,你还没从上一讲的 CRUD 思维中走出来,下意识地想:

“取消订单?不就是把订单状态改成Cancelled吗?这简单!”

于是你写出了这样的代码:

// PATCH /api/v1/orders/:id { "status": "cancelled" }

你觉得这很 RESTful,很规范。但几天后,问题来了:

  • 有的开发人员直接改了数据库状态,但忘了发短信。

  • 有的在退库存时发生了错误,但订单状态却已经变更为取消了,导致数据不一致。

  • 前端同学跑来问:“为什么我把状态改成cancelled报错了?哦,原来只有pending状态才能取消啊,你不早说?”

其实,这里犯了一个典型的“过度 CRUD 化”错误。

并不是所有的业务逻辑都能(或者应该)被映射为字段的修改。对于那些副作用大、逻辑复杂、具有明确业务意图的操作,我们需要引入一种新的设计模式:自定义方法(Custom Methods)

今天这一讲,我们就来聊聊当 CRUD 不够用时,如何在 Gin 中优雅地设计“非标行为”。

为什么PATCH不是万能的?

在 API 设计中,有一条黄金法则:API 应当表达“意图”,而非仅仅暴露“数据”。

使用PATCH更新状态字段,虽然符合 REST 的字面含义,但它掩盖了业务的复杂性。

  1. 副作用(Side Effects)隐藏PATCH通常暗示着轻量级的数据字段更新。但“取消订单”可能触发一系列沉重的后端流程(退款、通知、库存释放)。将这些副作用隐藏在一个简单的字段更新背后,违背了“最小惊讶原则”。

  2. 状态机逻辑泄露:订单的状态流转通常是有严格限制的(比如只能从Pending->Cancelled)。如果使用PATCH,意味着客户端需要了解这些流转规则,否则就会收到各种不知所云的校验错误。

  3. 权限粒度难控制:如果“修改收货地址”和“取消订单”都走PATCH /orders/:id,你怎么在网关层做细粒度的权限控制?难道要解析 Body 内容吗?

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/26 4:56:43

不是吧,都2025年了你别说你还不会Spring MVC基本应用

1.1 经典三层结构 在JavaEE开发中,几乎全部都是基于B/S架构的开发。那么在B/S架构中,系统标准的三层架构包括:表现层、业务层、持久层。三层架构在我们的实际开发中使用得非常多,接下来我们详细了解下这三层架构。 表现层&#…

作者头像 李华
网站建设 2026/6/26 17:32:42

Wan2.2-T2V-A14B是否开放LoRA微调接口?社区开发者关注焦点

Wan2.2-T2V-A14B是否开放LoRA微调接口?社区开发者关注焦点 在AI生成内容(AIGC)浪潮席卷全球的今天,文本到视频(Text-to-Video, T2V)技术正从实验室走向实际生产环境。相比图像生成,视频生成不仅…

作者头像 李华
网站建设 2026/6/24 21:53:11

第九篇 异常统一处理

异常统一处理的优势提高代码可维护性 通过集中管理异常处理逻辑,避免重复代码,减少因异常处理分散导致的维护困难。统一处理机制使修改和扩展异常处理策略更加便捷。增强系统健壮性 统一捕获未处理的异常,防止程序意外终止。通过预设的降级策…

作者头像 李华
网站建设 2026/6/25 14:17:32

NVIDIA Profile Inspector完全攻略:释放显卡隐藏性能

NVIDIA Profile Inspector完全攻略:释放显卡隐藏性能 【免费下载链接】nvidiaProfileInspector 项目地址: https://gitcode.com/gh_mirrors/nv/nvidiaProfileInspector NVIDIA Profile Inspector是一款能够深度挖掘NVIDIA显卡性能的利器。与官方控制面板相比…

作者头像 李华
网站建设 2026/6/24 23:20:10

腾讯用“LLM+GNN“双剑合璧,广告推荐GMV暴涨2.8%!小白也能学会的冷启动解决方案

摘要 传统的广告召回单一模型往往难以有效平衡“语义精准”与“关系覆盖”、“冷启动”与“实时性”之间的结构性矛盾。为应对这一挑战,腾讯广告技术团队提出了融合 LLM 与 GNN 的创新方案,采用“GNN挖掘关系、LLM解析语义”的协同机制。 该方案既保留了…

作者头像 李华