Spring MVC(学习笔记五)--控制器的注解(四) -之全局异常处理操作

前面我们学习了两篇关于 控制器的注解,分别讲了@RequestMapping的使用 和 处理方法的参数配置及返回值配置

今天,我们来学学全局异常处理

主要注解:

@ControllerAdvice 定义全局异常处理类

@ExceptionHandler 声明异常处理方法

全局异常处理:                                                                                       

首先我们先来编写一个存在异常的处理方法:

类名:ExceptionHandlerController(访问路径:/ehc)

@GetMapping(value = "saoi")
public String setArrayOutIndex(){
    int[] a={}; //var a=[]
    a[10]=1123;
    return "index";
}

@ExceptionHandler的详细介绍:


第一种:直接在GlobalControllerAdiviceController中写:

@ControllerAdvice
public class GlobalControllerAdiviceController {
    @ExceptionHandler(value = {ArrayIndexOutOfBoundsException.class})
    @ResponseBody
    public String handlerArrayOutIndexExc(ArrayIndexOutOfBoundsException a){
        System.out.println("handler error............");
        return a.toString();
    }
}


第二种:首先我们定义一个异常处理实体类:ErrorInfo

public class ErrorInfo {
    private String code; //错误编码
    private String msg; //错误信息描述
    public String getCode() {
        return code;
    }
    public void setCode(String code) {
        this.code = code;
    }
    public String getMsg() {
        return msg;
    }
    public void setMsg(String msg) {
        this.msg = msg;
    }
}
再定义一个全局处理异常的类: GlobalControllerAdiviceController
@ControllerAdvice
public class GlobalControllerAdiviceController {
    @ExceptionHandler(value = {ArrayIndexOutOfBoundsException.class})
    @ResponseBody  //{code:10000002,msg:}
    public ErrorInfo handlerArrayOutIndexExc(ArrayIndexOutOfBoundsException a){
        System.out.println("handler error............");
        ErrorInfo errorInfo=new ErrorInfo();
        errorInfo.setCode("1000000001");
        errorInfo.setMsg(a.toString());
        return errorInfo;
    }
}
然后编写一个errors.jsp页面:
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
    <title>errors</title>
</head>
<body>
exception:
<hr>
${exception}
</body>
</html>
最后我们要在spring-mvc.xml中配置异常处理解析:
 <!--  异常处理解析  -->
<bean id="exceptionResolver" class="org.springframework.web.servlet.handler.SimpleMappingExceptionResolver">
    <property name="exceptionMappings">
        <props>
            <!-- 异常与视图的映射操作-->
            <prop key="java.lang.Exception">errors</prop>
            <prop key="java.lang.Throwable">errors</prop>
        </props>
    </property>
    <!-- 设置日志输出级别,不定义则默认不输出警告等错误日志信息 -->
    <property name="warnLogCategory" value="WARN"/>
    <!-- 默认错误页面,当找不到上面mappings中指定的异常相应视图时,使用本默认配置 -->
    <property name="defaultErrorView" value="errors"/>
    <!-- 默认HTTP状态码 -->
    <!--<property name="defaultStatusCode" value="500"/>-->
</bean>


优缺点:

  • 优点:将 Controller 层的异常和数据校验的异常进行统一处理,减少模板代码,减少编码量,提升扩展性和可维护性。
  • 缺点:只能处理 Controller 层未捕获(往外抛)的异常,对于 Interceptor(拦截器)层的异常,Spring 框架层的异常,就无能为力了。


猜你喜欢

转载自blog.csdn.net/qq_40594137/article/details/79235097