SpringBoot 项目统一 API 响应结果封装示例

在Spring Boot项目中,统一 API 响应结果封装是一种常用的技术实践,旨在提高开发效率、降低代码重复率,并提供一致的API响应格式,从而简化前后端交互和错误处理。

封装内容

响应结果封装是将后端服务返回的响应数据按照统一的格式进行封装,这个格式通常包括状态码、状态信息(或称为消息)、返回数据等关键信息。

  • 状态码(Code):表示请求的处理结果,如成功、失败、特定错误等。状态码通常是一组预定义的整数或枚举值。
  • 状态信息/消息(Message):与状态码相对应的文本描述,用于提供关于请求处理结果的更多信息。
  • 返回数据(Data):实际业务处理的结果数据,其类型可能因API而异。

此外,有些封装还会包含时间戳、请求ID等附加信息,以便于日志追踪和问题排查。

封装示例

1、Result

package com.wen.data;

import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Data;
import lombok.NoArgsConstructor;

/**
 * 统一 API 响应结果封装
 */
@Data
@Builder
@AllArgsConstructor
@NoArgsConstructor
public class Result<T> {

    private int code;

    private String message;

    private T data;

    public Result<T> setCode(ResultCode resultCode) {
        this.code = resultCode.code;
        this.message = resultCode.message;
        return this;
    }

    public Result<T> setMessage(String message) {
        this.message = message;
        return this;
    }

    public Result<T> setData(T data) {
        this.data = data;
        return this;
    }
}

2、ResultCode

package com.wen.data;

/**
 * 响应码枚举
 */

public enum ResultCode {

    // 这里可以根据多个场景设置不同的响应码,供前端判断问题并进行解释
    SUCCESS(1,"SUCCESS"),

    FAIL(400,"FAIL"),

    NOT_FOUND(401,"interface not found"),

    ERROR(500,"System Exception!");

    public int code;

    public String message;

    ResultCode(int code, String message){
        this.code = code;
        this.message = message;
    }
}

3、ResultGenerator

package com.wen.data;

/**
 * 响应结果生成
 */

public class ResultGenerator {

    public static Result<?> genSuccessResult(){
        return new Result<>().setCode(ResultCode.SUCCESS);
    }

    public static Result<?> genSuccessResult(Object data){
        return new Result<>().setCode(ResultCode.SUCCESS).setData(data);
    }

    public static Result<?> genFailResult(String message){
        return new Result<>().setCode(ResultCode.FAIL).setMessage(message);
    }

    public static Result<?> genSpecialResult(ResultCode resultCode, String message){
        return new Result<>().setCode(resultCode).setMessage(message);
    }
}

4、TestController

package com.wen.controller;

import com.wen.data.Result;
import com.wen.data.ResultGenerator;
import com.wen.dto.TbUser;
import com.wen.service.TestService;
import org.apache.ibatis.annotations.Param;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;

@RestController
@RequestMapping("/test")
public class TestController {

    @Autowired
    private TestService testService;

    @GetMapping("/select")
    public Result<?> selectUserByPage(
    				@Param("pageSize") Integer pageSize, 
    				@Param("pageNumber") Integer pageNumber){
    	// 生成结果
        return ResultGenerator.genSuccessResult(testService.selectUserByPage(pageSize, pageNumber));
    }
}

5、生成结果

{
    "code": 1,
    "message": "SUCCESS",
    "data": "2024-07-19"
}
Spring Boot的Controller层处理请求时,通常需要返回统一的数据格式给前端。为了实现这一点,开发者经常会创建一个通用的响应对象类(ResponseEntity或自定义的DTO类)。这里提供一个简单的示例,展示如何定义一个基础的响应数据对象类,以及如何在Controller中使用它来返回统一格式的数据。 首先,创建一个基础的响应数据对象类,例如名为`ApiResponse`的类,用于封装所有API响应数据: ```java import java.util.HashMap; import java.util.Map; public class ApiResponse { // 状态码 private Integer code; // 消息 private String message; // 数据 private Object data; public ApiResponse() { } public ApiResponse(Integer code, String message, Object data) { this.code = code; this.message = message; this.data = data; } // ... 省略getter和setter方法 ... public static ApiResponse success(Object data) { return new ApiResponse(200, "成功", data); } public static ApiResponse success(Object data, String message) { return new ApiResponse(200, message, data); } public static ApiResponse fail(Integer code, String message) { return new ApiResponse(code, message, null); } // ... 其他辅助方法 ... } ``` 然后,在Controller层使用这个`ApiResponse`类来返回响应: ```java import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.RestController; import java.util.HashMap; import java.util.Map; @RestController public class MyController { @GetMapping("/example") public ApiResponse example() { Map<String, Object> data = new HashMap<>(); data.put("key1", "value1"); data.put("key2", "value2"); return ApiResponse.success(data, "获取数据成功"); } } ``` 在上面的例子中,我们定义了一个简单的`ApiResponse`类,包含状态码、消息和数据。`example`方法使用这个类来构造一个成功的响应
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值