概述
Spring MVC的处理器拦截器类似于Servlet开发中的过滤器Filter,用于对处理器进行预处理和后处理。开发者可以自己定义一些拦截器来实现特定的功能。过滤器与拦截器的区别:拦截器是AOP思想的具体应用。
过滤器
1.servlet规范中的一 部分,任何java web工程都可以使用.
2.在url-pattern中配置了/*之后,可以对所有要访问的资源进行拦截
拦截器
1.拦截器是SpringMVC框架自己的,只有使用了Spring MVC框架的工程才能使用
2.拦截器只会拦截访问的控制器方法,如果访问的是jsp/html/css/image/js是不会进行拦截的
自定义拦截器
那如何实现拦截器呢?
想要自定义拦截器,必须实现HandlerInterceptor接口。
1.在application.xml中配置
<mvc:interceptors>
<mvc:interceptor>
<!--/**表示拦截所有-->
<mvc:mapping path="/**"/>
<bean class="com.mi.config.MyInterceptor"/>
</mvc:interceptor>
</mvc:interceptors>
2.编写拦截器
public class MyInterceptor implements HandlerInterceptor {
//return true:执行下一个拦截器,放行
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
System.out.println("----------处理前----------");
return true;
}
public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
System.out.println("----------处理后----------");
}
public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
System.out.println("----------清理----------");
}
}
测试代码:
@RestController
public class InterceptController {
@GetMapping("/t1")
public String test1(){
System.out.println("test1被执行");
return "OK";
}
}
测试结果: