SpringBoot 逻辑异常统一处理

构建项目

我们将逻辑异常核心处理部分提取出来作为单独的jar供其他模块引用,创建项目在parent项目pom.xml添加公共使用的依赖,配置内容如下所示:

<dependencies>
        <!--Lombok-->
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <optional>true</optional>
        </dependency>
        <!--测试模块依赖-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
        <!--web依赖-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
</dependencies>

项目创建完成后除了.ideaimlpom.xml保留,其他的都删除。

异常处理核心子模块

/**
 * @author WGR
 * @create 2019/9/7 -- 15:06
 */
public class OssException extends RuntimeException implements Serializable {
?
    private static final long serialVersionUID = 1L;
?
    private Object[] errFormatArr;
?
    public OssException(String message,Object... obj) {
        super(message);
        this.errFormatArr = obj;
    }
?
    //由于实际需要,因此又追加以下两种构造方法
    public OssException(String message, Throwable cause) {
        super(message, cause);
    }
?
    public OssException(Throwable cause) {
        super(cause);
    }
?
    public Object[] getErrFormatArr() {
        return errFormatArr;
    }
?
    public void setErrFormatArr(Object[] errFormatArr) {
        this.errFormatArr = errFormatArr;
    }
}

统一返回结果定义

@Slf4j
@ControllerAdvice
public class OssExceptionHandler  {
?
    @ExceptionHandler(value = Exception.class)
    @ResponseBody
    public ModelAndView handle(Exception ex) {
        //使用FastJson提供的FastJsonJsonView视图返回,不需要捕获异常
        FastJsonJsonView view = new FastJsonJsonView();
?
        R result = null;
        if (ex instanceof OssException) {//自义异常
            result = M.getErrR(ex.getMessage(),((OssException) ex).getErrFormatArr());
        }else if(ex instanceof MaxUploadSizeExceededException) {//Spring的文件上传大小异常
            result = M.getErrR("exception.maxUploadSizeExceededException",PropUtil.getInteger("upload.maxSize"));
        }else if(ex instanceof DataAccessException) {//Spring的JDBC异常
            result = M.getErrR("exception.dataAccessException");
        }else {//其他未知异常
            result = M.keyErrR("exception.other");
        }
?
        //开发过程中打印一下异常信息,生产过程可关闭
        if(result.getErrCode() != 60113) { //20181225 登陆会话失效,不打印了
            String stackTrace = StackUtil.getStackTrace(ex);
            log.error("----->"+stackTrace);
        }
?
?
        //电脑端,封装异常信息 20181128 安全测试问题要求关闭详细异常信息
        //if(WebUtil.isComputer()) result.setErrdetail(stackTrace);
        result.setErrdetail(ex.getMessage()); //20190128 异常信息简易的还需加入
        view.setAttributesMap(result);
?
        return new ModelAndView(view);
    }
?
?
?
}

由于种种原因,只能贴出部分代码,可以提供思路。

原文地址:https://www.cnblogs.com/dalianpai/p/11756148.html

时间: 2024-10-13 04:17:49

SpringBoot 逻辑异常统一处理的相关文章

spring @ExceptionHandler注解方式实现异常统一处理

首先,在我们的工程中新建BaseController父类,内容如下: package com.ztesoft.zsmartcity.framework.exception; import java.io.IOException;import java.io.PrintWriter;import java.io.StringWriter;import java.util.Date;import javax.servlet.ServletException;import javax.servlet.

Spring MVC异常统一处理(异常信息的国际化,日志记录)

JAVA EE项目中,不管是对底层的数据操作,还是业务层的处理过程,还是控制层的处理,都不可避免的会遇到各种可预知的(业务异常主动抛出).不可预知的异常需要处理.一般dao层.service层的异常都会直接抛出,最后由controller统一进行处理,每个过程都单独处理异常,且要考虑到异常信息和前端的反馈,代码的耦合度高,不统一,后期维护的工作也多. 同时还必须考虑异常模块和日志模块.国际化的支持. 因此需要一种异常处理机制将异常处理解耦出来,这样保证相关处理过程的功能单一,和系统其它模块解耦,

Spring MVC异常统一处理(包括普通请求异常以及ajax请求异常)

通常SpringMVC对异常的配置都是返回某个jsp视图给用户,但是通过ajax方式发起请求,即使发生异常,前台也无法获得任何异常提示信息.因此需要对异常进行统一的处理,对于普通请求以及ajax请求的异常都有效. 1.Spring MVC的异常处理机制 Spring MVC 通过HandlerExceptionResolver处理程序的异常,包括处理器映射,数据绑定以及处理器执行时发生的异常.HandlerExceptionResolver仅有一个接口方法: ModelAndView resol

SPL异常类之 LogicException 逻辑异常

SPL 提供了一系列标准异常.LogicException 是从 Exception 基类派生的,没有添加任何附加方法.抛出逻辑异常和抛出标准一次的方法类似,区别在于逻辑异常须在应用程序编写有误时才抛出. logicexception异常: 异常表示程序逻辑错误.这种异常应在代码中直接导致修复.

Jersey Rest 异常统一处理机制

前言: 异常分为运行时异常和非运行时异常,所谓的运行时异常是指那些不需要异常捕获的异常,总是交由虚拟机接管,如:ArrayIndexOutOfBoundsException,我们在写程序时,并没有使用try..catch来捕获它. 以前,我们进行项目开发时,习惯性的喜欢使用大量的try...catch...finally方法来进行异常处理,并且,只是将异常信息保存到log日志中即可,并没有将一些异常信息以可读性的方式返回给前端用户.而在一些比较大的项目中,进行异常统一处理是架构师或项目经理必须考

spring mvc 异常统一处理 【转】

SpringMVC 提供的异常处理主要有两种方式,一种是直接实现自己的HandlerExceptionResolver,另一种是使用注解的方式实现一个专门用于处理异 常的Controller——ExceptionHandler.前者当发生异常时,页面会跳到指定的错误页面,后者同样,只是后者会在每个 controller中都需要加入重复的代码.如何进行简单地统一配置异常,使得发生普通错误指定到固定的页面,ajax发生错直接通过js获取,展现给 用户,变得非常重要.下面先介绍下2种异常处理方式,同时

springmvc请求参数异常统一处理,结合钉钉报告信息定位bug位置

参考之前一篇博客:springmvc请求参数异常统一处理 1.ExceptionHandlerController package com.oy.controller; import java.text.MessageFormat; import java.util.ResourceBundle; import javax.servlet.http.HttpServletRequest; import org.springframework.beans.TypeMismatchException

springboot全局异常拦截源码解读

在springboot中我们可以通过注解@ControllerAdvice来声明一个异常拦截类,通过@ExceptionHandler获取拦截类抛出来的具体异常类,我们可以通过阅读源码并debug去解读springboot的异常拦截机制. 在了解异常拦截机制之前,我引用他人图片大致介绍下springmvc的大致调用流程 异常拦截处理流程: 1. 首先会调用DispatcherServlet的doDispatch分发请求 2. 通过processDispatchResult方法处理分发结果 3.

解决springboot 出现异常: java.net.BindException: Address already in use: bind

解决springboot 出现异常: java.net.BindException: Address already in use: bind 这是引文在启动springboot 的时候,没有关闭端口号8080(或者自定义的端口号),需要进行手动关闭. 操作步骤: 1,windows+R -->cmd,进入命令窗口. 2,命令行内输入 :netstat   -ano|findstr  8080 8080指的是你启动的时候的端口号 查找最后一列的pid. 命令行输入: taskkill  /pid