与SpringMVC中的Filter类似,用于拦截mapping的路径。
拦截器的定义:
package com.test.controller.interceptor;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.springframework.web.servlet.HandlerInterceptor;
import org.springframework.web.servlet.ModelAndView;
public class Interceptor111 implements HandlerInterceptor {
@Override
public boolean preHandle(HttpServletRequest request, HttpServletResponse response,
Object object) throws Exception {
System.out.println("被Interceptor111拦截器拦截");
System.out.println("doSomthing");
System.out.println("放行");
/**
* 若返回true,则放行;若返回false,则不放行。
* 这里假设放行
*/
return true;
}
@Override
public void postHandle(HttpServletRequest request, HttpServletResponse response,
Object object, ModelAndView mv) throws Exception {
}
@Override
public void afterCompletion(HttpServletRequest request, HttpServletResponse response,
Object object, Exception ex) throws Exception {
}
}
- preHandle: 在请求处理之前进行调用(Controller方法调用之前)
- postHandle: 请求处理之后进行调用,但是在视图被渲染之前(Controller方法调用之后)
- afterCompletion: 在整个请求结束之后被调用,也就是在DispatcherServlet 渲染了对应的视图之后执行(主要是用于进行资源清理工作)
拦截器配置的适配器:
package com.test.config;
import com.test.controller.interceptor.Interceptor111;
import com.test.controller.interceptor.Interceptor222;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.InterceptorRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurerAdapter;
@Configuration
public class WebMvcConfigurer extends WebMvcConfigurerAdapter {
@Override
public void addInterceptors(InterceptorRegistry registry) {
/**
* 拦截器会按照顺序执行
*/
registry.addInterceptor(new Interceptor111()).addPathPatterns("/one/**");
// 可以追加地址
registry.addInterceptor(new Interceptor222()).addPathPatterns("/two/**").addPathPatterns("/one/**");
super.addInterceptors(registry);
}
}
要点:
- 需要使用@Configuration注解,用于配置拦截器
- 继承WebMvcConfigurerAdapter(相当于声明它是一个配置的适配器)
- 重写addInterceptors方法添加需要的拦截器地址(即mapping路径),可根据业务需求重写。
参考源于: