请求PUT方法的模型应该与GET方法的响应模型属于同一类吗?

问题描述

在我的应用中,后端将使用一个端点来获取和更新数据(使用GET和PUT方法)。两种操作使用完全相同的JSON模式。问题是,我是否还应该对更新请求正文和获取响应正文使用相同的模型?您能告诉我分离和组合它们的利弊吗?

谢谢。

解决方法

请求PUT方法的模型应该与GET方法的响应模型属于同一类吗?

请参见RFC 7231

对给定表示形式的成功PUT建议,在同一目标资源上进行后续GET将导致在200(OK)响应中发送等效表示形式。

通常,PUT请求与该目标uri的成功GET响应具有相同的Media Type

HTTP定义了消息的语义,但不限制实现(请参见Fielding 2002)。

也就是说,如果GET和PUT使用的表述由于相同的原因而改变,那么通用实现是合理的,因此当这两个路径共享相同的基础模型时,维护代码可能会更容易。

如果是同一个班级,那么“单一责任原则”又如何呢?

我的回答是,在这种情况下,“单一责任原则”实际上并不能使您的代码变得更好,因此您不使用它。您可以通过多种方法来概括该想法。一个是您正在使用数据结构,而不是“对象”。另一个是该信息正在越界,at the boundaries,applications are not object-oriented.

表达这个想法有些不同:这里的职责是单一的(在消息的内存表示中管理一些职责),但是有两个不同的 roles ; GET方案的出站角色(您需要能够将消息转换为字节,描述内容类型等),PUT方案的入站角色(您需要从中提取信息单元)数据结构)。

相关问答

依赖报错 idea导入项目后依赖报错,解决方案:https://blog....
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下...
错误1:gradle项目控制台输出为乱码 # 解决方案:https://bl...
错误还原:在查询的过程中,传入的workType为0时,该条件不起...
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct...