概述
1. @ExceptionHandler处理类内异常
在Controller类中,使用@ExceptionHandler来注解处理异常的方法,来告诉SpringMVC,这个方法专门处理这个类内controller方法抛出的异常
@ExceptionHandler 注解定义的方法优先级问题:例如发生的是 NullPointerException,但是声明的异常有RuntimeException 和 Exception,此时会根据异常的最近继承关系找到继承深度最浅的那个 @ExceptionHandler 注解方法,即标记了 RuntimeException 的方法,即精确优先
/*
* 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
<body>
<h1>出错啦!</h1>
<h1>错误信息:${ex }</h1>
</body>
2. @ExceptionHandler处理全局异常
避免在每个Controller类中都写入相同的类异常处理方法,将处理全局异常的类加入IOC容器中
@ControllerAdvice注解专门用来注解异常类
如Controller类内的@ExceptionHandler 注解方法不能处理抛出的异常,那么会找@ControllerAdvice中的@ExceptionHandler 注解方法来进行异常处理
@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 解析到,
然后使用这个注解的属性进行处理。
自定义一个异常类
@ResponseStatus(value=HttpStatus.FORBIDDEN,reason=" 用户名称和密码不匹配")
public class UserNotMatchException extends RuntimeException {}
Controller方法抛出异常
@RequestMapping("/testResponseStatus")
public String testResponseStatus(@RequestParam("i") int i ){
if(i == 13){
throw new UserNotMatchException();
}
System.out.println("testResponseStatus");
return "success";
}
<% pageContext.setAttribute("ctp", request.getContextPath() %>
<a href = "${ctp }/testResponseStatus?i=13">测试testResponseStatus</a>
<!--
等价于 <a href="testResponseStatus?i=13"></a>
-->
4.SimpleMappingExceptionResolver 全局异常处理(不必写异常处理类)
直接在springMVC配置文件中配置异常的处理页面,避免了写异常类
<!-- 配置全局异常处理的处理器: -->
<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. @ExceptionHandler处理类内异常2. @ExceptionHandler处理全局异常3.ResponseStatusExceptionResolver处理自定义异常4.SimpleMappingExceptionResolver 全局异常处理(不必写异常处理类)所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
发表评论 取消回复