【重温SSM框架系列】9 - SpringMVC中的拦截器和异常处理
SpringMVC中的拦截器和异常处理
- 拦截器
-
- 拦截器和过滤器的区别
- 自定义拦截器
-
- 1. 创建MyInterceptor类并实现HandlerInterceptor接口
- 2. 在spring-mvc.xml中配置自定义的拦截器
- 异常处理
-
- 简单异常处理器SimpleMappingExceptionResolver
- 自定义异常处理器
-
- 1. 创建创建异常处理器类并实现HandlerExceptionResolver
- 2. 配置自定义异常处理器
大家好,我是【1+1=王】, 热爱java的计算机(人工智能)渣硕研究生在读。
如果你也对java、人工智能等技术感兴趣,欢迎关注,抱团交流进大厂!!!
Good better best, never let it rest, until good is better, and better best.近期会重新温习一下SSM的相关知识,相应的博客会更新至专栏【SSM框架】中,欢迎大家关注!
SSM专栏:https://blog.csdn.net/weixin_43598687/category_11652306.html
拦截器
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()方法
在所以流程结束之后执行。
@Controllerpublic 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: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"/>
SSM专栏:https://blog.csdn.net/weixin_43598687/category_11652306.html