概述
SpringMVC的处理器拦截器类似于Servlet开发中的过滤器Filter,用于对处理器进行预处理和后处理。开发者可以自己定义一些拦截器来实现特定的功能。
过滤器与拦截器的区别:拦截器是AOP思想的具体应用,可以横切进去,对业务代码没有影响
过滤器
-
servlet规范中的一部分,任何java web工程都可以使用
-
在url-pattern中配置了/*之后,可以对所有要访问的资源进行拦截
拦截器
-
拦截器是SpringMVC框架自己的,只有使用了SpringMVC框架的工程才能使用
-
拦截器只会拦截访问的控制器方法, 如果访问的是jsp/html/css/image/js是不会进行拦截的
自定义拦截器
自定义一个拦截器,首先创建一个类需要实现HandlerInterceptor 接口,并且将这个类在spring配置文件里进行配置
类的创建如下:
由于是aop运用,所以横切的地方可以多处,如下,分别是处理前后,及清理后
特别注意处理前的函数有一个bo‘olean返回值,当返回值是true才放行,false就拦截
public class myInterceoptor implements HandlerInterceptor {
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
System.out.println("======处理前=======");
@Override
public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView) throws Exception {
System.out.println("======处理后=======");
}
@Override
public void afterCompletion(HttpServletRequest request, HttpServletResponse response, Object handler, Exception ex) throws Exception {
System.out.println("======清理=======");
}
}
spring文件配置如下:
mvc特有的,所以是<mvc开头
可以配多个拦截器,每个拦截器 需要配置两个属性
<mvc:interceptors>
<mvc:interceptor>
<mvc:mapping path="/**"/>
<bean class="com.hys.controller.myInterceoptor"/>
</mvc:interceptor>
</mvc:interceptors>
path 拦截的地方 这个路径指的是对应请求路径,包含了jsp和controller里的请求路径,而不是网页上直接输入*/index.jsp路径,是代码里写了的请求路径,如下图:
红框里的路径,所以拦截器在走这个方法时就会进行判断
有一个特别注意的。/WEB-INF 这个路径下的包,客户无法直接访问,要访问只能通过代码,jsp,controller,servlet等
/**包含了子路径,
<bean class 所使用的拦截器
测试: