关于异常的处理,这两个系统处理方法都是一致的,我们会自定义很多业务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>