抛出自定义异常

1.自定义异常

java 复制代码
@Getter
public class ServiceImplException extends RuntimeException {

    private ResultCode resultCode;

    public ServiceImplException(ResultCode resultCode) {
        this.resultCode = resultCode;
    }
}

ResultCode是一个枚举类,用来枚举出现的状态码和异常信息。

java 复制代码
@AllArgsConstructor
@Getter
public enum ResultCode {
    /** 定义状态码 */
    //操作成功
    SUCCESS                     (1000, "操作成功"),

    //服务器内部错误,友好提示
    ERROR                       (2000, "服务繁忙请稍后重试")
}

2.定义全局异常处理

实现代码:

java 复制代码
@Slf4j
@RestControllerAdvice
public class GlobalExceptionHandler<T> {
    @ExceptionHandler(HttpRequestMethodNotSupportedException.class)
    public Result<?>
    handleHttpRequestMethodNotSupported(HttpRequestMethodNotSupportedException e,
                                        HttpServletRequest request)
    {
        String requestURI = request.getRequestURI();
        log.error("请求地址'{}',不⽀持'{}'请求", requestURI, e.getMethod());
        return Result.failed(ResultCode.FAILED_USER_NOT_EXISTS);
    }
    /**
     * 拦截运⾏时异常
     */
    @ExceptionHandler(RuntimeException.class)
    public Result<?> handleRuntimeException(RuntimeException e, HttpServletRequest
            request) {
        String requestURI = request.getRequestURI();
        log.error("请求地址'{}',发⽣异常.", requestURI, e);
        return Result.failed(ResultCode.ERROR);
    }

    /**
     * 捕获service层的异常
     * @param e
     * @param request
     * @return
     */
    @ExceptionHandler(ServiceImplException.class)
    public Result<?> ServiceImplException(ServiceImplException e, HttpServletRequest request) {
        String requestURI = request.getRequestURI();
        ResultCode resultCode = e.getResultCode();
        log.error("请求地址'{}',发生业务异常.", requestURI, resultCode.getMsg(),e);
        return Result.failed(resultCode);
    }
    /**
     * 系统异常
     */
    @ExceptionHandler(Exception.class)
    public Result<?> handleException(Exception e, HttpServletRequest request) {
        String requestURI = request.getRequestURI();
        log.error("请求地址'{}',发⽣异常.", requestURI, e);
        return Result.failed (ResultCode. ERROR );
    }

    @ExceptionHandler(MethodArgumentNotValidException.class)
    public Result<?> handleBindException(Exception e, HttpServletRequest request) {
        String requestURI = request.getRequestURI();
        log.error("请求地址'{}',发⽣异常.", requestURI, e);
        return Result.failed (ResultCode.ERROR_FORMAT );
    }
}

注意两点:

一是需要在类上@RestControllerAdvice加上注解。

二是需要在相应的方法上加上@ExceptionHandler注解,后面跟上处理相应的异常。

最终达到的效果就是我们在服务层抛出相应的异常之后,这里会自动捕捉抛出的异常,但是抛出的异常必须是这里实现相应的逻辑的异常。

相关推荐
雨中飘荡的记忆13 小时前
保证金系统入门到实战
java·后端
Nyarlathotep011313 小时前
Java内存模型
java
暮色妖娆丶17 小时前
不过是吃了几年互联网红利罢了,我高估了自己
java·后端·面试
NE_STOP18 小时前
MyBatis-参数处理与查询结果映射
java
狂奔小菜鸡18 小时前
Day40 | Java中的ReadWriteLock读写锁
java·后端·java ee
SimonKing19 小时前
JetBrains 用户狂喜!这个 AI 插件让 IDE 原地进化成「智能编码助手」
java·后端·程序员
狂奔小菜鸡19 小时前
Day39 | Java中更灵活的锁ReentrantLock
java·后端·java ee
NE_STOP1 天前
MyBatis-配置文件解读及MyBatis为何不用编写Mapper接口的实现类
java
后端AI实验室2 天前
用AI写代码,我差点把漏洞发上线:血泪总结的10个教训
java·ai