springboot结果集封装自定义的响应数据格式(JSON)返回

仅作为个人学习总结

使用JSON作为统一响应数据格式

统一json格式的response,给出一组结果返回值的参考:

{
  "hasPrePage": false,
  "hasNextPage": false,
  "everyPage": 10,
  "totalPage": 1,
  "currentPage": 1,
  "beginIndex": 0,
  "totalCount": 6,
  "code": "SUCCESS",
  "data": [
    {
      "id": 163,
      "version": "V1.0",
      "status": 0,
      "cteUser": "learnfake",
      "uteUser": "learnfake",
      "cteTime": "2020-10-24 12:12:59",
      "uteTime": "2020-10-24 12:53:44",
      "retryCount": "3",
      "intervalTime": "1800",
      "timeOut": "7200",
      "adapterType": "json"
    }
  ]
}

返回的请求对象

定义http请求返回的最外层对象,封装返回数据的统一格式

/**
 * @Author wyrctzy
 * @Description http请求返回的最外层对象
 * @CreatedOn 2020/10/24
 */
 @Data
public class PageResult<T> {
    /** 错误码. */
    private Integer code;

    /** 提示信息. */
    private String msg;
    
    /** 具体的内容. */
    private T data;

}

tips:为了使得代码更加的简洁,使用了lombok注解@Data相当于加上了:
@Getter/@Setter get和set方法
@ToString ToString方法
@EqualsAndHashCode 判等和哈希方法
@RequiredArgsConstructor 传参构造

直接在Controller中使用PageResult

如果不使用工具类时,我们将不得不频繁的New出结果集对象,并对其返回需要的属性值进行填充,代码比较丑:

 @GetMapping("")
    public PageResult<List> list() {
        int total = fakeNewsApp.total(params, condition);
        List<FakenewsDTO> fakeNewsDTOList = fakeNewsApp.list();
        PageResult pageResult = new PageResult();
        pageResult.setCode(0);
        pageResult.setMsg("SUCCESS");
        pageResult.setData(fakeNewsDTOList);
        return pageResult;
    }

定义结果集的工具类PageResultUtil

为了可以达到代码复用目的,由于很多时候如果需要返回结果都必须new Result()的话代码整体就会非常的冗长而且都基本是相同的内容,因此有必要在这里增加一个工具类:class PageResultUtil
可以看到上述在返回这个结果之前需要一顿New和Set,这就导致需要的东西越多罗列的就会越长,为了避免上面出现的代码冗余情况,就应该增加工具类,封装请求失败和成功时候的方法,使用静态方法:

public class PageResultUtil {

    public static PageResult success(Object object) {
        PageResult pageResult = new PageResult();
        pageResult.setCode(0);
        pageResult.setMsg("SUCCESS");
        pageResult.setData(fakeNewsDTOList);
        pageResult.setData(object);
        return result;
    }

    public static PageResult success(Integer code, String msg) {
        PageResult pageResult = new PageResult();
        pageResult.setCode(code);
        pageResult.setMsg("SUCCESS" + msg);
        return pageResult;
    }

    public static PageResult error(Integer code, String msg) {
        PageResult pageResult = new PageResult();
        pageResult.setCode(code);
        pageResult.setMsg("ERROR" + msg);
        return pageResult;
    }
}

使用结果集工具类PageResultUtil

简洁!仅作为示例:

 @GetMapping("")
    public PageResult<List> list() {
        int total = fakeNewsApp.total(params, condition);
        List<FakenewsDTO> fakeNewsDTOList = fakeNewsApp.list();
        returnPageResult.success(fakeNewsDTOList);
    }

后续继续学习,对于异常处理和全局异常捕获的封装和使用

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
SpringBoot通过使用统一的数据返回格式可以提高开发效率和代码的可维护性。返回统一的JSON数据格式可以统一前后端之间的数据交互方式,减少沟通成本,并且提高了代码的可读性和可维护性。 在SpringBoot中,可以定义一个全局异常处理器(GlobalExceptionHandler),用于捕获和处理全局的异常。在异常处理器中,可以定义一个统一的数据返回格式,包括状态码、提示信息和返回数据。当发生异常时,异常处理器会将异常信息封装成统一的JSON数据格式返回给前端,以便前端进行处理。 为了实现统一的数据返回格式,可以定义一个响应对象(ResponseObject),包含对应的状态码、提示信息和返回数据。在业务逻辑处理中,统一使用ResponseObject来封装返回的数据,然后再返回给前端。 在控制器层中,可以使用ResponseEntity对象来返回统一的JSON数据格式。通过使用ResponseEntity.ok()方法可以返回一个状态码为200的成功响应,然后将ResponseObject对象作为响应的数据。这样,无论是成功还是失败,都能以统一的JSON数据格式返回给前端。 在返回数据时,可以添加一些通用的字段,如请求ID、访问时间等,以便用于日志记录和跟踪。 通过采用统一的JSON数据返回格式,可以提高代码的可读性、可维护性和规范性,方便前后端的协作和沟通。同时,也可以方便后期的维护和扩展,减少了代码的冗余和重复编写。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值