拦截器
Spring MVC 的拦截器类似于Servlet 开发中的过滤器Filter,用于对处理器进行预处理和后处理。
拦截器和过滤器的区别
过滤器Filter | 拦截器Interceptor | |
---|---|---|
使用范围 | servlet 规范中的一部分,任何Java Web 工程都可以使用 | SpringMVC 框架自己的,只有使用了SpringMVC 框架的工程才能用 |
拦截过滤范围 | 在url-pattern 中配置了/*之后,可以对所有要访问的资源拦截 | 在<mvc:mappingpath=“”/>中配置了/**之后,也可以多所有资源进行拦截,但是可以通过<mvc:exclude-mappingpath=“”/>标签排除不需要拦截的资源 |
自定义拦截器
1. 创建MyInterceptor类并实现HandlerInterceptor接口
HandlerInterceptor接口为org.springframework.web.servlet.HandlerInterceptor
public class MyInterceptor implements HandlerInterceptor {
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
System.out.println("preHandle执行了.......");
return true;
}
@Override
public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
System.out.println("postHandle执行了.......");
}
@Override
public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
System.out.println("afterCompletion执行了.......");
}
}
实现HandlerInterceptor接口后可以重写三个方法:
- preHandle()方法
在Controller中的业务方法执行之前执行。
- postHandle()方法
在Controller中的业务方法执行之后,视图对象返回之前执行。
- afterCompletion()方法
在所以流程结束之后执行。
@Controller
public class InterceptorController {
@RequestMapping("/inter")
@ResponseBody
public ModelAndView interceptorTest(){
System.out.println("Controller中的业务方法开始执行");
ModelAndView modelAndView = new ModelAndView("success");
modelAndView.addObject("msg","wybegin");
return modelAndView;
}
}
2. 在spring-mvc.xml中配置自定义的拦截器
<!--mvc的注解驱动-->
<mvc:annotation-driven conversion-service="conversionService"/>
<!--拦截器-->
<mvc:interceptors>
<mvc:interceptor>
<mvc:mapping path="/**"/>
<bean class="com.wang.interceptor.MyInterceptor"/>
</mvc:interceptor>
</mvc:interceptors>
异常处理
SpringMVC中的异常处理思路是:当Dao、Service、Controller出现异常时都通过throws Exception向上抛出,最后由SpringMVC前端控制器交由异常处理器进行异常处理。
SpringMVC提供了两种异常处理的方式:自带的简单异常处理处、自定义异常处理器。
简单异常处理器SimpleMappingExceptionResolver
这是SpringMVC已经定义好了的异常处理器,在使用时可以根据项目情况进行相应异常与视图的映射配置。
<!-- 简单异常处理器 -->
<bean class="org.springframework.web.servlet.handler.SimpleMappingExceptionResolver">
<property name="defaultErrorView" value="default_error"/>
<property name="exceptionMappings">
<map>
<entry key="java.lang.NullPointerException" value="null_error"/>
<entry key="java.lang.NumberFormatException" value="format_error"/>
</map>
</property>
</bean>
当发生的异常没有被配置时,就会跳转到默认的页面:
自定义异常处理器
1. 创建创建异常处理器类并实现HandlerExceptionResolver
public class MyExceptionResolver implements HandlerExceptionResolver {
@Override
public ModelAndView resolveException(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Object o, Exception e) {
ModelAndView mav = new ModelAndView();
// 发生异常时跳转的页面
mav.setViewName("default_error");
return mav;
}
}
2. 配置自定义异常处理器
<!-- 自定义异常处理器 -->
<bean id="exceptionResolver" class="com.wang.exception.MyExceptionResolver"/>