SpringBoot高级用法

本文介绍了SpringBoot的高级用法,包括如何实现统一的异常处理,定义异常枚举和业务异常,添加全局异常处理器,并在业务代码中应用。同时,文章还讲解了如何进行统一格式的响应输出,以及如何利用log4j配置实现HTTP请求唯一标识的打印,以便于问题定位。提供了具体的代码改造和log4j配置变动的详细步骤。

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

SpringBoot中高级用法

生产项目中一般会有项目改进

1、我们一般不会在controller中捕获异常进行处理,一般通过全局异常处理器进行拦截处理

2、为了让响应的格式进行统一,一般会对响应结果进行统一包装。

3、为了能够快速定位问题,一般会结合日志打印框架让每次http请求都能够打印一个唯一标识方便问题定位

1、统一异常处理

定义异常枚举

public enum ResultCode {

    /**
     * 成功
     */
    SUCCESS(0, "success"),

    FAIL(501,"操作失败"),

    /**
     * 未知错误
     */
    UNKNOWN_ERROR(500, "unkonwn error"),

    /**
     * 用户名错误或不存在
     */
    USERNAME_ERROR(401, "username error or does not exist"),

    /**
     * 密码错误
     */
    PASSWORD_ERROR(402, "password error"),

    /**
     * 用户名不能为空
     */
    USERNAME_EMPTY(403, "username can not be empty");

    /**
     * 结果码
     */
    private int code;

    /**
     * 结果码描述
     */
    private String msg;


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

    public int getCode() {
        return code;
    }

    public String getMsg() {
        return msg;
    }

}

定义业务异常

import cn.educate.boot.demo.enu.ResultCode;

/**
 * @author yinchong
 * @create 2021/4/25 16:24
 * @description 业务异常类
 */
public class BizRuntimeExcption extends RuntimeException {
    int code;
    String msg;

    public BizRuntimeExcption(ResultCode resultCode) {
        super(resultCode.getMsg());
        this.code = resultCode.getCode();
        this.msg = resultCode.getMsg();
    }

    public BizRuntimeExcption(int code, String msg) {
        super(msg);
        this.code = code;
        this.msg = msg;
    }

    public int getCode() {
        return code;
    }

    public void setCode(int code) {
        this.code = code;
    }

    public String getMsg() {
        return msg;
    }

    public void setMsg(String msg) {
        this.msg = msg;
    }
}

添加全局异常处理器

import cn.educate.boot.demo.enu.ResultCode;
import cn.educate.boot.demo.model.dto.ResultDTO;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.web.bind.annotation.ControllerAdvice;
import org.springframework.web.bind.annotation.ExceptionHandler;
import org.sp
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值