spring boot 如何优雅地实现 RESTful,统一结果封装有没有必要

2020-05-15 16:34:52 +08:00
 muyunn

1.post 请求创建成功后应该 Http 状态码应该是 201,可以直接在 controller 方法上加一个 @ResponseStatus(HttpStatus.CREATED),但是整个项目写下来就感觉有点多了,有没有什么好的办法,可以 post 请求成功后自己返回 201?

2.为什么要有统一结果封装?自己在公司开发的项目还有很多开源项目都做了统一结果封装,无论任何请求 Http 状态码都返回 200,然后根据封装的 code 做响应,这样有必要吗,为什么不使用 Http 状态码来做判断,直接返回给前端一个业务对象呢?

1713 次点击
所在节点    程序员
6 条回复
IMCA1024
2020-05-15 16:42:15 +08:00
1: 好像 Spring data rest 返回的好像是挺严格的 HTTP 状态码


2. 关于第二点:无论任何请求 Http 状态码都返回 200,然后根据封装的 code 做响应,这样有必要吗,为什么不使用 Http 状态码来做判断,直接返回给前端一个业务对象呢?

HTTP 状态码 200 只是代表这次请求是成功,但如果是业务里面的多种错误 ,靠 HTTP 状态码并不能解决问题阿。。。
IMCA1024
2020-05-15 16:45:55 +08:00
Spring Boot 优雅实现 RESTful 的话 结合 Spring data jpa / rest 。 我曾经做过一个项目
就是 Spring Boot + Spring data rest (JPA) 返回都是超媒体格式 ,跟前端对接起来,前端同事苦不堪言。

RESTful 说到底是一种规范, 在我印象比较深的一句话(大概是这样的内容,也涉及到一个 RESTful 的成熟度模型),
是关于对 RESTful 的:
URL 定位资源,HTTP 动词描述操作,返回格式为超媒体。
chendy
2020-05-15 16:48:10 +08:00
1. 成功了的请求区分状态码意义不是很大,除非真的有区分“新建”“更新”的必要
2. “全部 200 + 自定义格式” 和 “http 错误码 + 成功失败返回不同内容” 是两种风格,从摸鱼的角度,第二种需要自己写的东西更少所以我觉得更好…
HENQIGUAI
2020-05-15 17:04:31 +08:00
《 Java 开发手册》泰山版附 3:错误码列表可供参考,其实主要是约定的业务状态
optional
2020-05-15 17:07:35 +08:00
统一给 200 意味着放弃了成熟的 web 监控,日志分析等一大堆已有的工具,然后自己做一遍轮子去做这些事。
EastLord
2020-05-15 17:10:10 +08:00
又开始讨论状态码了。。。

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

https://www.v2ex.com/t/672082

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

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

© 2021 V2EX