关于异常的处理,这两个系统处理方法都是一致的,我们会自定义很多业务Exception,还有RUNTimeException,然后通过 Spring的HandlerExceptionResolver去进行全局捕获,不论你在系统哪里去throw,只要实现了 HandlerExceptionResovler这个接口,Spring都会拦截下异常进行处理。
以下是我做的一个简单的测试:
package com.haininghacker.web; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import org.springframework.web.servlet.HandlerExceptionResolver; import org.springframework.web.servlet.ModelAndView; public classCommonExceptionResolver implements HandlerExceptionResolver{ @Override publicModelAndView resolveException(HttpServletRequest arg0, HttpServletResponse arg1, Object arg2, Exception arg3) { // TODOAuto-generated method stub ModelAndView modelAndView = newModelAndView(); modelAndView.setViewName("index"); return modelAndView; } }
?另外还需要在xml文件里面进行下面的配置:
<bean class="com.haininghacker.web.CommonExceptionResolver"></bean>
?
然后你就可以对系统任何地方throw出来的异常进行统一处理了。
Spring会去搜索容器里面所有实现了HandlerExceptionResolver接口的class,直到返回一个ModelAndView对象。
其实Spring已经为我们实现了一个简单的异常处理,它就是:SimpleMappingExceptionResolver。
不过,需要进行如下配置:
<bean class="org.springframework.web.servlet.handler.SimpleMappingExceptionResolver"> <!-- 定义默认的异常处理页面,当该异常类型的注册时使用 --> <property name="defaultErrorView" value="error"></property> <!-- 定义异常处理页面用来获取异常信息的变量名,默认名为exception --> <property name="exceptionAttribute" value="ex"></property> <!-- 定义需要特殊处理的异常,用类名或完全路径名作为key,异常也页名作为值 --> <property name="exceptionMappings"> <props> <prop key="IOException">error/ioexp</prop> <prop key="java.sql.SQLException">error/sqlexp</prop> </props> </property> </bean>
?