如何设计API接口,实现统一格式返回?
前言 在移动互联网,分布式、微服务盛行的今天,现在项目绝大部分都采用的微服务框架,前后端分离方式,(题外话:前后端的工作职责越来越明确,现在的前端都称之为大前端,技术栈以及生态圈都已经非常成熟;以前后端人员瞧不起前端人员,那现在后端人员要重新认识一下前端,前端已经很成体系了)。 一般系统的大致整体架构图如下:
接口交互 前端和后端进行交互,前端按照约定请求URL路径,并传入相关参数,后端服务器接收请求,进行业务处理,返回数据给前端。
后端服务器如何实现把数据返回给前端? 返回格式 后端返回给前端我们一般用JSON体方式,定义如下:
CODE状态码 code返回状态码,一般小伙伴们是在开发的时候需要什么,就添加什么。 如接口要返回用户权限异常,我们加一个状态码为101吧,下一次又要加一个数据参数异常,就加一个102的状态码。这样虽然能够照常满足业务,但状态码太凌乱了 我们应该可以参考HTTP请求返回的状态码
我们可以参考这样的设计,这样的好处就把错误类型归类到某个区间内,如果区间不够,可以设计成4位数。
这样前端开发人员在得到返回值后,根据状态码就可以知道,大概什么错误,再根据message相关的信息描述,可以快速定位。关注微信公众号 Java后端 获取更多推送。 Message 这个字段相对理解比较简单,就是发生错误时,如何友好的进行提示。一般的设计是和code状态码一起设计,如 再在枚举中定义,状态码 状态码和信息就会一一对应,比较好维护。 Data 返回数据体,JSON格式,根据不同的业务又不同的JSON体。 我们要设计一个返回体类Result 控制层Controller 我们会在controller层处理业务请求,并返回给前端,以order订单为例 我们看到在获得order对象之后,我们是用的Result构造方法进行包装赋值,然后进行返回。小伙伴们有没有发现,构造方法这样的包装是不是很麻烦,我们可以优化一下。关注微信公众号 Java后端 获取更多推送。 美观美化 我们可以在Result类中,加入静态方法,一看就懂 【免责声明】本站内容转载自互联网,其相关言论仅代表作者个人观点绝非权威,不代表本站立场。如您发现内容存在版权问题,请提交相关链接至邮箱:bqsm@foxmail.com,我们将及时予以处理。 |
-
前言 前面我们用了几篇文章系统的说了一下有关Java并...[详细]
-
1.目标场景 不知道你有没有经历过这样一个场景,好不...[详细]
-
背景 这两天在打docker的时候,发现自己的容器启动之后...[详细]
-
为了帮开发者审查代码漏洞,微软 GitHub 又收购了一家公司
本文转自雷锋网,如需转载请至雷锋网官网申请授权。 2...[详细]
-
并发扣款一致性优化,CAS下ABA问题,这个话题还没聊完!!!
上一篇答星球水友提问,《并发扣款,如何保证数据的一...[详细]
-
1. 前言 本文主要探讨Linux运维技术人员会被淘汰吗? ...[详细]
-
在程序开发时候一套好的开发环境和工具栈,可以帮我们...[详细]
-
本篇文章将详细介绍解析式的基本要素及其各种形式。 P...[详细]
-
go语言用来执行一个系统的命令相对python来说还是有点...[详细]
-
Kubernetes肯定不会是第一个受制于其规模的开源项目,...[详细]