文章目录
- 一、拦截器
- 1、拦截器简介
- (1)什么是拦截器
- (2)拦截器的作用
- (3)拦截器与filter过滤器的区别
- 2、创建拦截器
- (1)创建类实现HandlerInterceptor接口
- (2)重写接口里面的三个方法
- (3)在springMVC.xml配置拦截器
- 3、多个拦截器拦截方法执行顺序
- 二、异常处理器
- 1、默认异常处理机制DefaultHandlerExceptionResolver
- 2、自定义异常处理器SimpleMappingExceptionResolver
- (1)基于配置实现
- (2)基于配置异常处理机制
一、拦截器
1、拦截器简介
(1)什么是拦截器
拦截器(Interceptor)是动态拦截方法调用的机制,用来拦截控制器方法的执行。和过滤器一样,拦截器需要在web.xml里面配置。
(2)拦截器的作用
- 在指定方法调用前后执行预先设定的方法。
- 阻止原始方法的执行
(3)拦截器与filter过滤器的区别
- 技术类别不同:filter过滤器是servlet的技术,拦截器是SpringMVC的技术。
- 执行的范围不同:filter对所有的访问增强,拦截器只对SpringMVC访问增强。
2、创建拦截器
(1)创建类实现HandlerInterceptor接口
public class TestInterceptor implements HandlerInterceptor {
}
(2)重写接口里面的三个方法
public class TestInterceptor implements HandlerInterceptor {
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
return HandlerInterceptor.super.preHandle(request, response, handler);
}
@Override
public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
HandlerInterceptor.super.postHandle(request, response, handler, modelAndView);
}
@Override
public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
HandlerInterceptor.super.afterCompletion(request, response, handler, ex);
}
}
- preHandle():在控制器方法执行之前执行
- postHandle():在控制器方法执行之后执行
- afterCompletion():处理完视图和模型数据,渲染视图之后执行
(3)在springMVC.xml配置拦截器
第一种配置:通过bean标签配置
<!-- 配置拦截器-->
<mvc:interceptors>
<bean class="com.cx.interceptor.TestInterceptor"></bean>
</mvc:interceptors>
只配置一个bean的方式,会拦截所有路径的内容。配置拦截器之后如果preHandle方法返回值时false,会拦截对应路径,返回值为true表示放行。
第二种配置:通过引用spring容器里面的对象
<mvc:interceptors>
<ref bean="testInterceptor"></ref>
</mvc:interceptors>
第三种配置方式:配置拦截范围
<mvc:interceptors>
<mvc:interceptor>
<mvc:mapping path="/*"/>
<mvc:exclude-mapping path="/"/>
<ref bean="testInterceptor"></ref>
</mvc:interceptor>
</mvc:interceptors>
<mvc:mapping >配置将要拦截的路径
<mvc:exclude-mapping >排除拦截的路径
3、多个拦截器拦截方法执行顺序
三个重写的拦截方法执行顺序取决于配置在spring.xml配置文件中配置的顺序。preHandle()按照配置在配置文件里的顺序按顺序执行,postHandle()、afterCompletion()按逆序执行
我配置两个拦截器:
<mvc:interceptors>
<bean class="com.cx.interceptor.TestInterceptor"></bean>
<bean class="com.cx.interceptor.TestInterceptor2"></bean>
</mvc:interceptors>
执行效果:
二、异常处理器
springMvc中处理控制器方法执行过程中所出现异常的接口:HandlerExceptionResolver
这个接口下面有两个常用的异常处理实现类:DefaultHandlerExceptionResolver和
SimpleMappingExceptionResolver
1、默认异常处理机制DefaultHandlerExceptionResolver
这个异常处理器是SpringMVC为我们提供的默认异常处理器,我们在SpringMVC里面出现的异常都被这个异常处理器处理过。
如下图所示,默认异常处理器返回的是ModelAndView,ModelAndView是用来渲染视图和模型数据的,简单来说就是出现指定异常之后这个异常处理器会跳转到指定页面,并且携带对应响应数据。然后默认异常处理器为我们处理了许多异常,如下图中的HttpRequestMethodNotSupportedException,这个异常就是请求方式不被支持的异常,会返回一个405的状态码。还有其它的异常处理,HttpMessageNotWritableException、ServletRequestBindingException等等,这些异常都是在默认异常处理器里面定义好的,出现异常后会调用这个默认异常处理器。
2、自定义异常处理器SimpleMappingExceptionResolver
这个异常处理器是用来处理自定义异常,如果控制器方法中出现了异常,我们可以利用这个异常处理器指定视图,让其跳转到指定页面。
(1)基于配置实现
自定义异常处理可以在SpringMVC的配置文件中配置指定的异常处理。bean标签里面配置的是自定义异常全类名,property 标签name=“exceptionMappings” 配置异常映射,property 标签 name="exceptionAttribute"配置将异常处理信息放到指定域中,通过后面配置的键名可以得到指定异常信息。一对props标签配置一种异常处理机制,prop 标签的key是异常类型,标签里面是出现该异常后跳转的视图名称。
<!-- 配置异常处理器-->
<bean class="org.springframework.web.servlet.handler.SimpleMappingExceptionResolver">
<property name="exceptionMappings">
<props>
<prop key="java.lang.ArithmeticException">error</prop>
</props>
</property>
<property name="exceptionAttribute" value="ex"></property>
</bean>
造了一个异常,出现异常后跳到了自定义异常视图。
@RequestMapping("/responseBody")
@ResponseBody
public String responseBody(){
int i=1/0;
return "hello responseBody!!!";
}
(2)基于配置异常处理机制
我们也可以用注解方式实现同上面配置文件功能。@ControllerAdvice注解表示该类是一个异常处理类,@Controller的扩展注解,同样能标识这个类到spring容器里面;@ExceptionHandler注解中的value就是处理的异常类型;下面方法的返回值就是出现异常后跳转到的视图,方法里面的Exception 参数用来获取异常处理信息,model则是用来处理模型数据,就是将异常信息响应到前端页面。
@ControllerAdvice
public class ExceptionController {
@ExceptionHandler(value = {ArithmeticException.class})
public String testException(Exception ex, Model model){
model.addAttribute("ex",ex);
return "error";
}
}
最后效果和配置方式一样: