SpringBoot实战:统一响应和异常处理详细教程 (附git源码)



简介

  • 我们通常接触的项目大多已经是前后端分离的项目,前后端的数据交互往往封装成统一的JSON格式。
  • 封装统一的响应体结构
{
 "code" : 20000,
 "message" : "操作成功",
 "data" : null
}
  • 统一的异常处理
    我们使用@RestControllerAdvice结合@ExceptionHandler,并继承ResponseEntityExceptionHandler支持web类的错误处理。

1. 依赖

  • pom.xml
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>

2. 封装响应体

  • ResponseResult 通用响应体
/**
 * 通用响应体
 *
 * @author qiding
 */
@Data
@Accessors(chain = true)
public class ResponseResult<T> implements Serializable {

    private static final long serialVersionUID = -1L;

    private Integer code;

    private String message;

    private T data;

    public ResponseResult(Integer code, String message, T data) {
        super();
        this.code = code;
        this.message = message;
        this.data = data;
    }

    private static <T> ResponseResult<T> build(Integer code, String message, T data) {
        return new ResponseResult<>(RespCode.OK.code, message, data);
    }
    
    public static <T> ResponseResult<T> ok(T data) {
        return build(RespCode.OK.code, RespCode.OK.message, data);
    }

    private static <T> ResponseResult<T> ok(String message, T data) {
        return build(RespCode.OK.code, message, data);
    }
    
    public static <T> ResponseResult<T> fail() {
        return fail(RespCode.ERROR.message);
    }
    
    public static <T> ResponseResult<T> fail(String message) {
        return fail(RespCode.ERROR, message);
    }
    
    public static <T> ResponseResult<T> fail(RespCode respCode, String message) {
        return build(respCode.getCode(), message, null);
    }
    
    public enum RespCode {
        /**
         * 业务码
         */
        OK(20000, "请求成功"),
        MY_ERROR(20433, "自定义异常"),
        UNAUTHORIZED(20401, "未授权"),
        LOGIN_FAIL(20402, "账号或密码错误"),
        ERROR(20400, "未知异常");

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

        private final int code;
        private final String message;

        public int getCode() {
            return code;
        }

        public String getMessage() {
            return message;
        }
    }
}

3. 全局异常处理

/**
 * 描述:全局统一异常处理
 * @author ding
 */
@Slf4j
@RestControllerAdvice
public class ExceptionHandlerAdvice {

   /**
     * 异常处理
     */
    @ExceptionHandler(value = Exception.class)
    public ResponseResult<String> defaultException(Exception e) {
        if (e instanceof NullPointerException){
            log.error("空指针异常:" + e.getMessage(), e);
            return ResponseResult.fail("空指针异常");
        }
        log.error("未知异常:" + e.getMessage(), e);
        return ResponseResult.fail();
    }
}

4. 效果测试

  • IndexController
@RestController
public class IndexController {

    /**
     * 基础web
     */
    @GetMapping("/")
    public ResponseResult<String> hello() {
        return ResponseResult.ok("hello");
    }

    @GetMapping("/err")
    public ResponseResult<String> error() {
        int i = 1 / 0;
        return ResponseResult.ok("模拟错误");
    }
}
  • 浏览器输入 ip:端口:/err
    在这里插入图片描述

6. 源码分享

  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

全栈小定

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值