1. @ExceptionHandler处理类内异常
在Controller类中,使用@ExceptionHandler来注解处理异常的方法,来告诉SpringMVC,这个方法专门处理这个类内controller方法抛出的异常
@ExceptionHandler 注解定义的方法优先级问题:例如发生的是 NullPointerException,但是声明的异常有RuntimeException 和 Exception,此时会根据异常的最近继承关系找到继承深度最浅的那个 @ExceptionHandler 注解方法,即标记了 RuntimeException 的方法,即精确优先
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17/* * value属性指明该方法能够处理的异常 * 如果value = Exception.class 则能够处理所有异常 * 可以为每种异常定制专属页面,发生异常后就跳转至该页面 * 当方法返回值类型为String时,return后即经过视图解析器跳转到页面 * 但这样就无法携带error信息(这里不可以使用Model来携带错误信息) * 要携带异常信息,必须返回ModelAndView ,并在参数列表里加上 Exception ex */ @ExceptionHandler(value = {ArithmeticException.class, NullPointerException.class}) public ModelAndView handleException( Exception ex ){ System.out.println(ex.getMessage()); ModelAndView view = new ModelAndView("myerror"); view.addObject("ex", ex); return view; }
myerror.jsp
1
2
3
4
5<body> <h1>出错啦!</h1> <h1>错误信息:${ex }</h1> </body>
2. @ExceptionHandler处理全局异常
避免在每个Controller类中都写入相同的类异常处理方法,将处理全局异常的类加入IOC容器中
@ControllerAdvice注解专门用来注解异常类
如Controller类内的@ExceptionHandler 注解方法不能处理抛出的异常,那么会找@ControllerAdvice中的@ExceptionHandler 注解方法来进行异常处理
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17@ControllerAdvice public class MyAllException{ @ExceptionHandler(value={java.lang.RuntimeException.class}) public ModelAndView handleException2(Exception ex){ System.out.println("发生RuntimeException异常,由全局异常处理..."+ex.getMessage()); ModelAndView mv = new ModelAndView("myerror"); mv.addObject("ex", ex); // myerror.jsp -> ${requestScope.ex } return mv; } }
3.ResponseStatusExceptionResolver处理自定义异常
HandlerExceptionResolver定义了每个异常的处理方法,@ExceptionHandler则是重新指定某个异常的处理方法。对于自定义异常,HandlerExceptionResolver不进行解析,故使用@ExceptionHandler注解也不会生效。
使用@ResponseStatus来修饰自定义异常,那么被抛出的自定义异常则会被ResponseStatusExceptionResolver 解析到,
然后使用这个注解的属性进行处理。
自定义一个异常类
1
2
3
4@ResponseStatus(value=HttpStatus.FORBIDDEN,reason=" 用户名称和密码不匹配") public class UserNotMatchException extends RuntimeException {}
Controller方法抛出异常
1
2
3
4
5
6
7
8
9
10@RequestMapping("/testResponseStatus") public String testResponseStatus(@RequestParam("i") int i ){ if(i == 13){ throw new UserNotMatchException(); } System.out.println("testResponseStatus"); return "success"; }
1
2
3
4
5
6
7
8<% pageContext.setAttribute("ctp", request.getContextPath() %> <a href = "${ctp }/testResponseStatus?i=13">测试testResponseStatus</a> <!-- 等价于 <a href="testResponseStatus?i=13"></a> -->
4.SimpleMappingExceptionResolver 全局异常处理(不必写异常处理类)
直接在springMVC配置文件中配置异常的处理页面,避免了写异常类
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26<!-- 配置全局异常处理的处理器: --> <bean class="org.springframework.web.servlet.handler.SimpleMappingExceptionResolver"> <!-- 配置order为-1,表示优先级最高 --> <property name="order" value="-1" /> <!-- 定义默认的异常处理页面,当该异常类型的注册时使用 --> <property name="defaultErrorView" value="error"></property> <!-- 不写exceptionAttribute,默认的异常信息的引用名:exception,可修改 在jsp页面,${ex }获取异常信息 --> <property name="exceptionAttribute" value="ex"></property> <!-- 定义需要特殊处理的异常,用类名或完全路径名作为key,异常页名作为值 --> <property name="exceptionMappings"> <props> <prop key="java.lang.RuntimeException">error-runtime</prop> <prop key="java.lang.ArithmeticException">error-arith</prop> <!-- 这里还可以继续扩展对不同异常类型的处理 --> </props> </property> </bean>
最后
以上就是大胆啤酒最近收集整理的关于SpringMVC--异常处理1. @ExceptionHandler处理类内异常2. @ExceptionHandler处理全局异常3.ResponseStatusExceptionResolver处理自定义异常4.SimpleMappingExceptionResolver 全局异常处理(不必写异常处理类)的全部内容,更多相关SpringMVC--异常处理1.内容请搜索靠谱客的其他文章。
发表评论 取消回复