很多同学搞不懂拦截器和过滤器的区别,我们先说一下他们的区别:
- 过滤器和拦截器非常相似,但是它们有很大的区别
- 最简单明了的区别就是过滤器可以修改request,而拦截器不能
- 过滤器需要在servlet容器中实现,拦截器可以适用于javaEE,javaSE等各种环境
- 拦截器可以调用IOC容器中的各种依赖,而过滤器不能
- 过滤器只能在请求的前后使用,而拦截器可以详细到每个方法
通俗的说过滤器就是筛选出你要的东西,比如requeset中你要的那部分
拦截器在做安全方面用的比较多,比如终止一些流程。
接下来我们举个简单的例子:
1、建立interceptor包,在此包下建立Interceptor类。此处我们以处理Ajax跨域请求为例,关于跨域请求,大家不懂的可以自行学习。代码如下:
public class Interceptor implements HandlerInterceptor {
public void afterCompletion(HttpServletRequest arg0, HttpServletResponse arg1, Object arg2, Exception arg3)
throws Exception {
// TODO Auto-generated method stub
}
public void postHandle(HttpServletRequest arg0, HttpServletResponse arg1, Object arg2, ModelAndView arg3)
throws Exception {
// TODO Auto-generated method stub
}
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object arg2) throws Exception {
response.setHeader("Access-Control-Allow-Origin", request.getHeader("Origin"));
response.setHeader("Access-Control-Allow-Methods", "*");
response.setHeader("Access-Control-Allow-Credentials", "true");
response.setHeader("Access-Control-Allow-Headers", "x-requested-with,content-type");
System.err.println("------------------>:已完成跨域处理");
return true;
}
}
注意此类实现了HandlerInterceptor接口。
2、我们还要注册一下此拦截器才能被springboot检测到,在config包下建立AppConfigurer类,代码如下:
@Configuration
public class AppConfigurer extends WebMvcConfigurerAdapter {
@Bean
public HandlerInterceptor getMyInterceptor() {
return new Interceptor();
}
@Override
public void addInterceptors(InterceptorRegistry registry) {
registry.addInterceptor(getMyInterceptor()).addPathPatterns("/**");
super.addInterceptors(registry);
}
}
注意此类继承了WebMvcConfigurerAdapter类。getMyInterceptor方法为拦截器实例注入方法。addInterceptors方法为说明拦截目标方法。此处我们所有请求都拦截。
3、测试结果如下:
拦截器配置成功。