使用 @ ExceptionHandler 注解
实现 HandlerExceptionResolver 接口
使用 @ControllerAdvice+ @ ExceptionHandler 注解
springmvc中自带的简单异常处理器
统一处理某一类异常,能够减少代码的重复度和复杂度,有利于代码的维护。
Spring 统一异常处理有 4 种方式,分别为:
使用 @ ExceptionHandler 注解
实现 HandlerExceptionResolver 接口
使用 @controlleradvice 注解
使用springmvc中自带的简单异常处理器
使用 @ ExceptionHandler 注解
使用@ExceptionHandler注解作用在方法上面,参数是具体的异常类型。一旦系统抛出这种类型的异常时,会引导到该方法来处理。但是它的缺陷很明显
处理异常的方法和出错的方法(或者异常最终抛出来的地方)必须在同一个controller,不能全局控制。
@ExceptionHandler(Exception.class)
public ModelAndView myException(Exception e) {
ModelAndView error = new ModelAndView("error");
error.addObject("error", e.getMessage());
return error;
}
实现 HandlerExceptionResolver 接口
springmvc提供一个HandlerExceptionResolver接口,自定义全局异常处理器必须要实现这个接口,如下:
@Component
public class MyException implements HandlerExceptionResolver {
@Override
public ModelAndView resolveException(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Object o, Exception e) {
ModelAndView error = new ModelAndView("error");
error.addObject("error",httpServletRequest.getRequestURI()+"错误:"+ e.getMessage());
return error;
}
}
使用 @ControllerAdvice+ @ ExceptionHandler 注解
@ExceptionHandler 可以返回 ModelAndView 定制异常视图。
@ControllerAdvice 是一个增强的 Controller,@ExceptionHandler 可以拦截特定的异常,因此可以更精确的配置异常处理逻辑。
@ControllerAdvice
public class MyException {
@ExceptionHandler(Exception.class)
public ModelAndView processException(Exception e){
ModelAndView error = new ModelAndView("error");
error.addObject("error", e.getMessage());
return error;
}
@ExceptionHandler(SQLException.class)
public ModelAndView processSQLException(SQLException e){
ModelAndView error = new ModelAndView("error");
error.addObject("error", e.getMessage());
return error;
}
}
springmvc中自带的简单异常处理器
springmvc中自带了一个异常处理器叫SimpleMappingExceptionResolver,该处理器实现了HandlerExceptionResolver 接口,全局异常处理器都需要实现该接口。我们要使用这个自带的异常处理器,首先得在springmvc.xml文件中配置该处理器:
<!-- 定义默认的异常处理页面 这里指向/WEB-INF/jsp/error.jsp-->
<property name="defaultErrorView" value="error"/>
<!-- 定义异常处理页面用来获取异常信息的变量名,也可不定义,默认名为exception -->
<property name="exceptionAttribute" value="ex"/>
<!-- 定义需要特殊处理的异常,这是重要点 -->
<property name="exceptionMappings">
<props>
<prop key="com.by.exception.MyException">error</prop>
</props>
<!-- 还可以定义其他的自定义异常 -->
</property>
页面异常信息获取: ${ex.message}
public class MyException extends Exception{
public MyException(){
super();
}
public MyException(String msg){
super(msg);
}
}
从上面的配置来看,最重要的是要配置特殊处理的异常,这些异常一般都是我们自定义的,根据实际情况来自定义的异常,然后也会跳转到不同的错误显示页面显示不同的错误信息