当前位置: 首页 > news >正文

【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 内容吗?

http://www.rkmt.cn/news/84446.html

相关文章:

  • 从零构建PHP扩展:基于Rust的高性能模块开发实战(完整源码级教程)
  • 2025 年 12 月苏作红木家具权威推荐榜:匠心传承与东方美学典范之选 - 品牌企业推荐师(官方)
  • 2025年PVC地板厂家权威推荐榜:导电/防静电/同质透心/复合/商用/磁性/自沉式,专业解析各品类核心优势与选购指南 - 品牌企业推荐师(官方)
  • 算力新标杆:昇腾Atlas 800T NPU实战Llama-2-7b全流程评测与技术解析
  • 联想Battery report准确吗,会显示错误吗
  • Wan2.2-T2V-A14B支持生成投票互动选项吗?短视频营销转化路径设计
  • 千亿参数落地革命:GLM-4.5V-FP8如何助力中小企业AI部署
  • 2025年12月AI培训与GEO服务商权威推荐榜:数字人、智能体、企业获客与短视频营销解决方案深度解析 - 品牌企业推荐师(官方)
  • 多人语音聊天室APP开发全解析:从技术架构到运营策略
  • 合并两个有序链表:双指针迭代法实现(C++)
  • Wan2.2-T2V-A14B已接入某头部视频平台AI剪辑工具链
  • 基于 openFuyao 的 AI 推理加速实战:智能路由与 PD 分离式 KVCache 架构揭秘
  • 2025 年 QMS 质量管理软件权威推荐榜:智能工厂与精益制造必备的数字化管控利器 - 品牌企业推荐师(官方)
  • 人工智能大模型技术突破:引领智能时代新纪元
  • 2025 年建筑加固技术权威推荐榜:碳纤维加固、粘钢加固等创新工艺深度解析与优质服务商精选 - 品牌企业推荐师(官方)
  • CVPR 2025最佳论文突破:DepthCrafter实现开放世界视频深度序列生成新范式
  • 突破跨模态生成瓶颈:Step-Video-TI2V开创图生视频技术新范式
  • 地平线苏治中:开源框架和基础模型赋能具身智能行业
  • 54、深入探索Shell编程:命令、变量与模式匹配的综合指南
  • Wan2.2-T2V-A14B在综艺节目花絮自动生成中的尝试
  • 51单片机:了解最小核心系统
  • 【VSCode量子编程环境搭建指南】:手把手教你5步配置Qiskit开发环境
  • 基于单片机大棚环境控制(温湿度,PH值)系统Proteus仿真(含全部资料)
  • 金融高频交易策略性能评估与优化框架
  • Java两种代理模式详解
  • 【北理工-AAAI26】MODA:首个无人机多光谱目标检测数据集
  • NVIDIA Profile Inspector完全攻略:释放显卡隐藏性能
  • Wan2.2-T2V-A14B能否生成符合ITU标准的国际电信联盟规范视频
  • 一文盘点家政有哪些类型
  • 英伟达全新语音识别模型Parakeet-TDT-0.6B-V2震撼发布:FastConformer架构引领英文语音处理新纪元