1. 简介
拦截器(Interceptor)类似于过滤器(Filter)
Spring MVC的拦截器作用是在请求到达控制器之前或之后进行拦截,可以对请求和响应进行一些特定的处理。拦截器可以用于很多场景下:
登录验证:对于需要登录才能访问的网址,使用拦截器可以判断用户是否已登录,如果未登录则跳转到登录页面。
权限校验:根据用户权限对部分网址进行访问控制,拒绝未经授权的用户访问。
请求日志:记录请求信息,例如请求地址、请求参数、请求时间等,用于排查问题和性能优化。
更改响应:可以对响应的内容进行修改,例如添加头信息、调整响应内容格式等。
拦截器和过滤器的区别在于它们的作用层面不同。
* 过滤器更注重在请求和响应的流程中进行处理,可以修改请求和响应的内容,例如设置编码和字符集、请求头、状态码等。
* 拦截器则更加侧重于对控制器进行前置或后置处理,在请求到达控制器之前或之后进行特定的操作,例如打印日志、权限验证等。
2. 定义拦截器
实现HandlerInterceptor接口 选择性实现preHandle、postHandle、afterCompletion方法
* preHandle:处理器方法调用之前执行
只有该方法有返回值,返回值是布尔类型,true放行,false拦截。
* postHandle:处理器方法调用之后执行
* afterCompletion:渲染完成后执行
java
public class Interceptor1 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执行啦");
}
}
3. 配置拦截器
方式一: 要在springmvc.xml中导入对应的包进行扫描
XML
<!--配置拦截器,基本方式:基于xml文件配置
注意:默认对所有请求进行拦截-->
<mvc:interceptors>
<!--第一种方式,导入全类名-->
<bean class="com.itgyl.springmvc.interceptors.Interceptor1"></bean>
</mvc:interceptors>
方式二:基于注解实现
XML
<!--配置拦截器,基本方式:基于xml文件配置
注意:默认对所有请求进行拦截-->
<mvc:interceptors>
<!--第二种方式,基于注解自动装配-->
<ref bean="interceptor1"></ref>
</mvc:interceptors>
java
@Component
public class Interceptor1 implements HandlerInterceptor {
4. 高级配置
XML
<!--拦截器高级配置-->
<mvc:interceptors>
<mvc:interceptor>
<!--对所有路径进行过滤-->
<mvc:mapping path="/**"/>
<!--除了该路径不过滤-->
<mvc:exclude-mapping path="/ok"/>
<ref bean="interceptor1"></ref>
</mvc:interceptor>
</mvc:interceptors>