SpringBoot统一返回格式的方法详解

2022-09-03 15:36:52 62 0
魁首哥

目录

  • 前言
  • 1. 直接返回结果
  • 2. 约定返回格式
  • 3. 返回统一格式结果
  • 4. 切片封装统一格式
    • 编写注解
    • 编写ControllerAdvice
    • 见证奇迹的时刻到了
  • 5. 自定义返回格式
    • 场景1:返回成功时code为200
    • 场景2:自定义返回格式

前言

目前很多项目都是前后端分离,前后端会事先约定好返回格式。那么后端如何做,才能优雅的返回统一格式呢,接下来,请大家跟着我,一步步来实现。

SpringBoot统一返回格式的方法详解

1. 直接返回结果

先看一下最基本的例子,直接将结果原封不动返回:

@Data
@AllArgsConstructor
@jsonIgnoreProperties(ignoreUnknown=true)
publicclassTestVo{

privatestaticfinallongserialVersionUID=1L;

@Schema(name="姓名")
privateStringname;

@Schema(name="年龄")
privateIntegerage;

}
@RestController
@RequestMapping(value="/test")
publicclassTestApi{

@GetMapping("/simple")
publicTestVosimple(){
TestVotestVo=newTestVo("张三",30);
returntestVo;
}
}

返回结果:

{
"name":"张三",
"age":30
}

2. 约定返回格式

假如已经与前端开发妹子约定好了格式,比如:

{
"code":0,
"msg":"错误信息",
"data":实际返回结果
}

那么我们首先需要编写一个封装结果类Result。为了方便封装,在这个类中增加一个success方法:

@Data
@JsonInclude(JsonInclude.Include.NON_NULL)
publicclassResult<T>implementsSerializable{

privatestaticfinallongserialVersionUID=1L;

/**
*返回编码
*/
privateIntegercode;

/**
*编码描述
*/
privateStringmsg;

/**
*业务数据
*/
privateTdata;

/**
*返回成功结果对象
*
*@paramdata
*@param<T>
*@return
*/
publicstatic<T>Result<T>success(Tdata){
Resultresult=newResult();
result.setCode(0);
result.setMsg("success");
result.setData(data);
returnresult;
}
}

3. 返回统一格式结果

后台接口代码微调一下,返回值改为Result,泛型为原返回值的类型:

@RestController
@RequestMapping(value="/test")
publicclassTestApi{

@GetMapping("/withResult")
publicResult<TestVo>withResult(){
TestVotestVo=newTestVo("张三",30);
returnResult.success(testVo);
}
}

返回结果:

{
"code":0,
"msg":"success",
"data":{
"name":"张三",
"age":30
}
}

至此,返回结果完美符合格式。

但是这样的代码并不算简洁:每个接口的返回值都必须是Result<>,并且return的时候都要用Result.success()方法封装一下。

那么,有没有更优雅的方法?我们继续往下看:

4. 切片封装统一格式

编写注解

实际使用场景中,并不是所有接口都需要统一格式。我们这里使用一个注解作为开关,按需控制接口返回格式。

@Target({ElementType.METHOD})
@Retention(RetentionPolicy.RUNTIME)
@Documented
public@interfaceApiResult{
Stringvalue()default"";

intsuccessCode()default0;

StringsuccessMsg()default"success";

Class<?extendsIResult>resultClass()defaultResult.class;
}

编写ControllerAdvice

@ControllerAdvice
publicclassMyResponseBodyAdviceimplementsResponseBodyAdvice{

protectedbooleanisStringConverter(ClassconverterType){
returnconverterType.equals(StringHttpMessageConverter.class);
}

protectedbooleanisApiResult(MethodParameterreturnType){
returnreturnType.hasMethodAnnotation(ApiResult.class);
}

@Override
publicbooleansupports(MethodParameterreturnType,ClassconverterType){
return!isStringConverter(converterType)&&isApiResult(returnType);
}

@Override
publicObjectbeforeBodyWrite(Objectbody,MethodParameterreturnType,MediaTypeselectedContentType,
ClassselectedConverterType,ServerHttpRequestrequest,ServerHttpResponseresponse){
//关键
returnResult.success(body);
}

}

这里有一点要注意,这个advice中supports方法中判断返回结果类型必须为非String类型。如果返回结果为String类型,那么result要转为json字符串后再返回,需要再写一个advice。

见证奇迹的时刻到了

@ApiResult
@GetMapping("/withResultHide")
publicTestVowithResultHide(){
TestVotestVo=newTestVo("张三",30);
returntestVo;
}

这段代码与最开始一样,并没有返回Result,仅仅加上了@ApiResult注解,我们看返回结果:

{
"code":0,
"msg":"success",
"data":{
"name":"张三",
"age":30
}
}

大功告成!

以上只是最精简的例子,实际使用中还结合了 统一异常封装、自定义返回格式 等功能。我们注意到@ApiResult注解中,有三个参数:successCode、successMsg、resultClass,就是为了自定义返回格式预留的,下面再看两个场景:

5. 自定义返回格式

场景1:返回成功时code为200

如果个别接口的返回格式与默认格式相同,但是要求code等于200时才代表成功,那么修改下successCode参数即可:

@ApiResult(successCode=200,successMsg="ok")
@GetMapping("/withResultHide")
publicTestVowithResultHide(){
TestVotestVo=newTestVo("张三",30);
returntestVo;
}

返回成功时,结果中的code和msg都变为设置的值:

{
"code":200,
"msg":"ok",
"data":{
"n恰卡编程网ame&qwww.cppcns.comuot;:"张三",
 "age":30
}
}

场景2:自定义返回格式

如果某个接口的返回格式不是默认的返回格式,比如约定返回returnCode、returnDesc、data(对应默认的code、msg、data)。那么则需要新增一个返回结果类,比如ReturnResult:

@Data
@JsonInclude(JsonInclude.Include.NON_NULL)
publihttp://www.cppcns.comcclassReturnResult<T>implementsSerializable{

privatestaticfinallongserialVersionUID=1L;

/**
*返回编码
*/
privateStringreturnCode;

/**
*编码描述
*/
privateStringreturnDesc;

/**
*业务数据
*/
privateTdata;

/**
*返回成功结果对象
*
*@paramdata
*@param<T>
*@return
*/
publicstatic<T>ReturnResult<T>success(Tdata){
ReturnResultresult=newReturnResult();
result.setReturnCode(0);
result.setReturnDesc("success");
result.setData(data);
returnresult;
}
}

然后修改接口上的@ApiResult注解中的resultClass属性

@ApiResult(resultClass=ReturnResult.class)
@GetMapping("/withResultHide")
publicTestVowithResultHide(){
TestVotestVo=newTestVo("张三",30);
returntestVo;
}

这时,返回结果就变为想要的格式了:

{
"returnCode":"0",
"returnDesc":"success",
"data":{
"name":"张三",
"age":30
}
}

到此这篇关于SpringBoot统一返回格式的方法详解的文章就介绍到这了,更多相关SpringBoot统一返回格式内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

收藏
分享
海报
0 条评论
62
上一篇:mybatis log4j2打印sql+日志实例代码 下一篇:Sentinel热点key限流的实现详解

本站已关闭游客评论,请登录或者注册后再评论吧~

忘记密码?

图形验证码