SpringBoot 统一返回数据格式及异常统一捕获返回数据格式

该博客介绍了如何在Spring MVC中实现统一的响应数据格式和异常处理。通过`ApiResponseHandler`类,所有Controller返回的数据都会被包装成`BaseResponse`对象,确保返回结构的一致性。当返回类型为String时,会先组装再转化为JSON。同时,`MyControllerAdvice`类用于全局捕获并处理异常,返回统一的错误信息。`BaseResponse`类提供了方便的方法来创建成功的或失败的响应。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

统一返回数据格式

import com.alibaba.druid.support.json.JSONUtils;
import org.springframework.core.MethodParameter;
import org.springframework.http.MediaType;
import org.springframework.http.converter.HttpMessageConverter;
import org.springframework.http.server.ServerHttpRequest;
import org.springframework.http.server.ServerHttpResponse;
import org.springframework.stereotype.Controller;
import org.springframework.web.bind.annotation.ControllerAdvice;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.servlet.mvc.method.annotation.ResponseBodyAdvice;

/**
 * 对Rest请求的返回结果进行统一包装
 */
@ControllerAdvice(annotations = {Controller.class, RestController.class})
public class ApiResponseHandler implements ResponseBodyAdvice<Object> {
    @Override
    public boolean supports(MethodParameter returnType, Class<? extends HttpMessageConverter<?>> converterType) {
        return true;
    }

    @Override
    public Object beforeBodyWrite(Object body, MethodParameter methodParameter, MediaType selectedContentType, Class<? extends HttpMessageConverter<?>> selectedConverterType, ServerHttpRequest request, ServerHttpResponse response) {
        String name = methodParameter.getParameterType().getName();
        if ("void".equals(name)) {
            return BaseResponse.ok();
        }
        if (body instanceof String) {
			
            return JSONUtils.toJSONString(BaseResponse.ok(body));
        }
        return BaseResponse.ok(body);

    }
}

注意:如果返回的格式为String类型,那么需要先进行组装,然后使用JSONUtils.toJSONString()转换下。

  • 效果
{
    "data": [
        {
            "id": "1001T11000000000170U",
            "code": "YC002",
            "name": "YC1.2",
            "displayName": "YC1.2",
            "abbrName": null
        }
    ],
    "status": 200,
    "message": "操作成功",
    "srvTime": 1647500769523
}

异常统一捕获返回数据格式

@ControllerAdvice
public class MyControllerAdvice {

    @ResponseBody
    @ExceptionHandler(Exception.class)
    public BaseResponse error(Exception e){
        return  BaseResponse.error();
    }
}
  • 效果:
{
    "data": null,
    "status": 500,
    "message": "失败",
    "srvTime": 1647500908548
}

统一返回包装类

@Data
@AllArgsConstructor
@NoArgsConstructor
public class BaseResponse<T> {

    private T data;
    private int status = 200;
    private String message;
    private long srvTime = System.currentTimeMillis();

    public BaseResponse(String message) {
        this.message = message;
    }

    public BaseResponse(int status) {
        this.status = status;
    }

    public BaseResponse(String message,int status) {
        this.message = message;
        this.status = status;
    }

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

    public static <T> BaseResponse<T> ok() {
        return new BaseResponse<>("操作成功");
    }

    public static <T> BaseResponse<T> ok(T data) {
        return new BaseResponse<T>("操作成功").setData(data);
    }

    public static <T> BaseResponse<T> error() {

        return new BaseResponse<>("失败",500);
    }

}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值