springboot项目中统一返回数据格式

统一API响应格式设计
本文介绍了一种统一API响应格式的设计方案,包括响应的状态码、消息及数据等关键元素,并通过示例展示了如何在实际项目中实现这一设计。

项目中我们会将响应封装成json返回,一般我们会将所有接口的数据格式统一, 使前端(iOS Android, Web)对数据的操作更一致、轻松。
一般情况下,统一返回数据格式没有固定的格式,只要能描述清楚返回的数据状态以及要返回的具体数据就可以。但是一般会包含状态码、返回消息、数据这几部分内容
例如,我们的系统要求返回的基本数据格式如下:
列表

{
  "success": true,
  "code": 20000,
  "message": "成功",
  "data": {
    "items": [
      {
        "id": "1",
        "name": "刘德华",
        "intro": "毕业于师范大学数学系,热爱教育事业,执教数学思维6年有余"
      }
    ]
  }
}

分页:

{
  "success": true,
  "code": 20000,
  "message": "成功",
  "data": {
    "total": 17,
    "rows": [
      {
        "id": "1",
        "name": "刘德华",
        "intro": "毕业于师范大学数学系,热爱教育事业,执教数学思维6年有余"
      }
    ]
  }
}

没有返回数据:

{
  "success": true,
  "code": 20000,
  "message": "成功",
  "data": {}
}

失败:

{
  "success": false,
  "code": 20001,
  "message": "失败",
  "data": {}
}

因此,我们定义统一结果:

{
  "success": 布尔, //响应是否成功
  "code": 数字, //响应码
  "message": 字符串, //返回消息
  "data": HashMap //返回数据,放在键值对中
}

一、创建接口定义返回码

public interface ResultCode {

    public static Integer SUCCESS = 20000;

    public static Integer ERROR = 20001;
}

这里的成功状态码和失败状态码可以自己进行修改

二、在公共模块common中编写一个R类

//统一返回值结果
@Data
public class R {

    @ApiModelProperty(value = "是否成功")
    private Boolean success;

    @ApiModelProperty(value = "返回码")
    private Integer code;

    @ApiModelProperty(value = "返回消息")
    private String message;

    @ApiModelProperty(value = "返回数据")
    private Map<String,Object> data=new HashMap<>();

    //构造器私有化:其他类在使用该类时不能够new
    private R(){}

    //返回静态成功方法
    public static R ok(){
        R r=new R();
        r.setSuccess(true);
        r.setCode(ResultCode.SUCCESS);
        r.setMessage("成功");
        return r;
    }

    //返回静态失败方法
    public static R error(){
        R r=new R();
        r.setSuccess(false);
        r.setCode(ResultCode.ERROR);
        r.setMessage("失败");
        return r;
    }

    //为了使用链式编程,以下方法返回值用this
    //R.ok().data()...

    public R success(Boolean success){
        this.setSuccess(success);
        return this;
    }

    public R message(String message){
        this.setMessage(message);
        return this;
    }

    public R code(Integer code){
        this.setCode(code);
        return this;
    }

    public R data(String key, Object value){
        this.data.put(key, value);
        return this;
    }

    public R data(Map<String, Object> map){
        this.setData(map);
        return this;
    }

}

其中的返回值可以由我们自己来定义

三、统一返回结果使用

在其它模块添加统一返回结果类所在的依赖:
例如:

<dependency>
    <groupId>com.atguigu</groupId>
    <artifactId>common_utils</artifactId>
    <version>0.0.1-SNAPSHOT</version>
</dependency>

接着修改controller中返回值的结果:
列表

@ApiOperation(value = "所有讲师列表")
@GetMapping
public R list(){
    List<Teacher> list = teacherService.list(null);
    return R.ok().data("items", list);
}

删除

@ApiOperation(value = "根据ID删除讲师")
@DeleteMapping("{id}")
public R removeById(
    @ApiParam(name = "id", value = "讲师ID", required = true)
    @PathVariable String id){
    teacherService.removeById(id);
    return R.ok();
}
Spring Boot项目中实现统返回对象R可以按照以下步骤进行: ### 实现统数据返回 可以通过重写 `responseAdvice` 方法以及实现 `ApiResponse` 类来实现统数据返回。这有助于将所有接口的返回数据格式进行统封装,方便前端处理和维护。例如在处理接口返回时,将实际的数据、状态码、消息等信息封装在统的 `ApiResponse` 对象中返回给前端 [^1]。 ### 依赖包导入 在使用 `validation` 数据校验注解进行分层数据校验与校验异常拦截器统返回处理时,需要进行依赖包的导入。虽然这主要是关于数据校验方面,但在实现统返回对象时,数据校验后的结果也需要以统的格式返回,所以依赖包的导入是整个流程的部分。正确导入相关依赖包可以确保项目中涉及的功能正常运行,包括统返回对象的处理流程 [^2]。 ### 代码示例 以下是个简单的示例代码,展示了如何在Spring Boot项目中实现统返回对象: ```java import com.mijiu.common.result.Result; import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController; @RestController @RequestMapping("/test1") public class Test1Controller { @GetMapping("/hello") public Result<String> hello() { return Result.success("hello world"); } } ``` 在这个示例中,`Result` 类即为统返回对象 `R`,通过 `Result.success` 方法可以将实际的数据封装在统返回对象中,并以统的格式返回给前端 [^3]。 ### 特殊类型处理 对于特殊类型如 `String`,需要进行特殊处理。在实现统返回对象时,要考虑到不同数据类型的处理逻辑,确保所有类型的数据都能以统的格式正确返回 [^1]。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值