如何进行统一异常处理

我们在项目中可以使用@ControllerAdvice注解结合@ExceptionHandler用于全局异常的处理,@ControllerAdvice学名是Controller增强器,作用是给Controller控制器添加统一的操作或处理。此注解结合方法型注解@ExceptionHandler,可用于捕获Controller中抛出的指定类型的异常,从而达到不同类型的异常区别处理的目的。

  • 定义全局异常处理类GlobalExceptionHandler,并在类上添加@ControllerAdvice注解,在异常方法上添加@ExceptionHandler注解。
    *

    java 复制代码
    package com.app.studypro.common;
    
    import lombok.extern.slf4j.Slf4j;
    import org.springframework.web.bind.annotation.ControllerAdvice;
    import org.springframework.web.bind.annotation.ExceptionHandler;
    import org.springframework.web.bind.annotation.ResponseBody;
    
    import java.sql.SQLIntegrityConstraintViolationException;
    
    /**
     * 统一异常处理逻辑
     *
     * @author Administrator
     */
    @Slf4j
    @ResponseBody
    @ControllerAdvice
    public class GlobalExceptionHandler {
    
        /**
         * 保存方法时触发的唯一性异常处理方法
         *
         * @param exception 错误
         * @return 返回异常信息
         */
        @ExceptionHandler(SQLIntegrityConstraintViolationException.class)
        public ResultBean<String> exceptionHandler(SQLIntegrityConstraintViolationException exception) {
            log.error(exception.getMessage());
            if (exception.getMessage().contains("Duplicate entry")) {
                String[] split = exception.getMessage().split(" ");
                String msg = split[2] + "已存在";
                return ResultBean.error(msg);
            }
            return ResultBean.error("未知错误");
        }
    
        /**
         * 自定义的异常处理方法
         *
         * @param exception 错误
         * @return 返回异常信息
         */
        @ExceptionHandler(CustomException.class)
        public ResultBean<String> exceptionHandler(CustomException exception) {
            log.error(exception.getMessage());
            return ResultBean.error(exception.getMessage());
        }
    
    }
相关推荐
SimonKing28 分钟前
OpenCode AI辅助编程,不一样的编程思路,不写一行代码
java·后端·程序员
FastBean36 分钟前
Jackson View Extension Spring Boot Starter
java·后端
Seven972 小时前
剑指offer-79、最⻓不含重复字符的⼦字符串
java
皮皮林55111 小时前
Java性能调优黑科技!1行代码实现毫秒级耗时追踪,效率飙升300%!
java
冰_河11 小时前
QPS从300到3100:我靠一行代码让接口性能暴涨10倍,系统性能原地起飞!!
java·后端·性能优化
桦说编程14 小时前
从 ForkJoinPool 的 Compensate 看并发框架的线程补偿思想
java·后端·源码阅读
躺平大鹅16 小时前
Java面向对象入门(类与对象,新手秒懂)
java
初次攀爬者17 小时前
RocketMQ在Spring Boot上的基础使用
java·spring boot·rocketmq
花花无缺17 小时前
搞懂@Autowired 与@Resuorce
java·spring boot·后端