springmvc配置全局异常处理

Spring3.0中对异常的处理方法一共提供了两种:一种是使用HandlerExceptionResolver接口;一种是在Controller类内部使用@ExceptionHandler注解。使用第一种方式可以实现全局异常控制,并且Spring已经提供了一个默认的实现类SimpleMappingExceptionResolver;使用第二种方式可以在Controller内部实现更个性化点异常处理方式,灵活性更高。一般来说,项目中只需要采用第一种方式就可以了,每个人都自己定义异常的展现方式,太过个性了,不统一。(我自己觉得配置SimpleMappingExceptionResolver比较方便

基于HandlerExceptionResolver接口的异常处理:

使用这种方式只需要实现resolveException方法,该方法返回一个ModelAndView对象,在方法内部对异常的类型进行判断,然后常见合适的ModelAndView对象,如果该方法返回了null,则Spring会继续寻找其他的实现了HandlerExceptionResolver 接口的Bean。换句话说,Spring会搜索所有注册在其环境中的实现了HandlerExceptionResolver接口的Bean,逐个执行,直到返回了一个ModelAndView对象。

示例代码:

Java代码  
  1. /** 
  2.  * 基于HandlerExceptionResolver接口的异常处理类 
  3.  * @author ZYWANG 2011-4-2 
  4.  */  
  5. public class CustomExceptionHandler implements HandlerExceptionResolver {  
  6.   
  7.     @Override  
  8.     public ModelAndView resolveException(HttpServletRequest request,  
  9.             HttpServletResponse response, Object object, Exception exception) {  
  10.         if(exception instanceof IOException){  
  11.             return new ModelAndView("errors/ioException");  
  12.         }else if(exception instanceof SQLException){  
  13.             return new ModelAndView("errors/sqlException");  
  14.         }  
  15.         return null;  
  16.     }  
  17.   
  18. }  

这个类必须声明到Spring中去,让Spring管理它,你可以使用@Component标签,也可以使用<bean/>节点。(这就是spring的灵活性支持自己扩展)

为了简单的进行异常处理,Spring提供了SimpleMappingExceptionResolver类,该类实现了HandlerExceptionResolver接口,需要使用时只需要使用<bean/>节点进行声明即可,示例如下:

Xml代码  
 
    <!-- 全局异常配置 start  控制器异常处理--> 
        <bean id="exceptionResolver" class="org.springframework.web.servlet.handler.SimpleMappingExceptionResolver"> 
            <property name="exceptionMappings"> 
                <props> 
                    <prop key="java.lang.Exception">errors/webException</prop> 
                    <prop key="java.lang.Throwable">errors/rmsException</prop> 
                </props> 
            </property> 
            <property name="statusCodes"> 
                <props> 
                    <prop key="errors/webException">500</prop> 
                    <prop key="errors/rmsException">404</prop> 
                </props> 
            </property> 
            <!-- 设置日志输出级别,不定义则默认不输出警告等错误日志信息 --> 
            <property name="warnLogCategory" value="WARN"></property> 
            <!-- 默认错误页面,当找不到上面mappings中指定的异常对应视图时,使用本默认配置 --> 
            <property name="defaultErrorView" value="errors/error"></property> 
            <!-- 默认HTTP状态码 --> 
            <property name="defaultStatusCode" value="500"></property> 
        </bean> 
        <!-- 全局异常配置 end --> 
通过SimpleMappingExceptionResolver我们可以将不同的异常映射到不同的jsp页 面(通exceptionMappings属性的配置),同时我们也可以为所有的异常指定一个默认的异常提示页面(通过defaultErrorView属性的配置),如果所抛出的异常在exceptionMappings 中没有对应的映射,则Spring将用此默认配置显示异常信息(注意这里配置的异常显示界面均 仅包括主文件名,至于文件路径和后缀已经在viewResolver中指定)   <property name="defaultErrorView" value="errors/error"></property>

一个典型的异常显示页面如下: 
<html> 
<head><title>Exception!</title></head> 
<body> 
<% Exception ex = (Exception)request.getAttribute("exception"); %> 
<H2>Exception: <%= ex.getMessage();%></H2> 
<P/> 
<% ex.printStackTrace(new java.io.PrintWriter(out)); %> 
</body> 
</html> 
exception 实在SimpleMappingExceptionResolver 被存放到request中的,具体可以查看源代码。 
如果SimpleMappingExceptionResolver无法满足异常处理的需要,我们可以针对 
HandlerExceptionResolver接口实现自己异常处理类,这同样非常简单(只需要实现一个 
resolveException方法)。 

如果有ViewResolver,则制定的jsp页面必须在那个页面下,到时候如果找不到页面,可以根据错误提示再调整页面路径

基于@ExceptionHandler的异常处理:

该方法需要定义在Controller内部,然后创建一个方法并用@ExceptionHandler注解来修饰用来处理异常,这个方法基本和 @RequestMapping修饰的方法差不多,只是可以多一个类型为Exception的参数,@ExceptionHandler中可以添加一个或多个异常的类型,如果为空的话则认为可以触发所有的异常类型错误。

示例代码:

Java代码  
  1. /** 
  2.  * 基于@ExceptionHandler异常处理 
  3.  * @author ZYWANG 2011-4-2 
  4.  */  
  5. @Controller  
  6. public class ExceptionHandlerController {  
  7.       
  8.     @ExceptionHandler(value={IOException.class,SQLException.class})  
  9.     public String exp(Exception ex,HttpServletRequest request) {  
  10.         request.setAttribute("exception", ex);  
  11.         return "/error.jsp";  
  12.     }  
  13.   

猜你喜欢

转载自songshidong.iteye.com/blog/1874482