通过实例解析java过滤器和拦截器的区别
区别
1.使用范围和规范不同
filter是servlet规范规定的,只能用在web程序中.
拦截器即可以用在web程序中,也可以用于application,swing程序中,是Spring容器内的,是Spring框架支持的
2.触发时机不同
顺序:Filter-->Servlet-->Interceptor-->Controller
- 过滤器是在请求进入容器后,但请求进入servlet之前进行预处理的。请求结束返回也是,是在servlet处理完后,返回给前端之前过滤器处理。
- 拦截器是方法到达Controller层之前生效的
3.过滤器的实现基于回调函数。而拦截器(代理模式)的实现基于反射,代理分静态代理和动态代理,动态代理是拦截器的简单实现。
何时使用拦截器?何时使用过滤器?
- 如果是非spring项目,那么拦截器不能用,只能使用过滤器。
- 如果是处理controller前后,既可以使用拦截器也可以使用过滤器。
- 如果是处理dispaterServlet前后,只能使用过滤器。
4.在action的生命周期中,拦截器可以多次被调用,而过滤器只能在容器初始化时被调用一次。
5.拦截器可以访问action上下文、值栈里的对象,而过滤器不能访问。
6.拦截器只能对action请求起作用,而过滤器则可以对几乎所有的请求起作用。
7.拦截器可以获取IOC容器中的各个bean,而过滤器就不行,在拦截器里注入一个service,可以调用业务逻辑。
SpringBoot使用过滤器
两种方式:
1、使用springboot提供的FilterRegistrationBean注册Filter
2、使用原生servlet注解定义Filter
两种方式的本质都是一样的,都是去FilterRegistrationBean注册自定义Filter
封装Filter
packagecom.theeternity.common.baseFilter;
importjavax.servlet.Filter;
/**
*@program:ApiBoot
*@description:封装Filter
*@author:TheEternityZhang
*@create:2019-02-1713:08
*/
publicinterfaceMappingFilterextendsFilter{
String[]addUrlPatterns();
intorder();
}
自定义Filter
packagecom.theeternity.beans.filterConfig;
importcom.theeternity.common.baseFilter.MappingFilter;
importlombok.extern.slf4j.Slf4j;
importorg.slf4j.Logger;
importorg.slf4j.LoggerFactory;
importjavax.servlet.*;
importjavax.servlet.FilterConfig;
importjava.io.IOException;
/**
*@program:ApiBoot
*@description:权限过滤器
*@author:TheEternityZhang
*@create:2019-02-1713:14
*/
publicclassAuthFilterimplementsMappingFilter{
@Override
publicString[]addUrlPatterns(){
returnnewString[]{"/*"};
}
@Override
publicintorder(){
return0;
}
@Override
publicvoidinit(FilterConfigfilterConfig)throwsServletException{
}
@Override
publicvoiddoFilter(ServletRequestservletRequest,ServletResponseservletResponse,FilterChainfilterChain)throwsIOException,ServletException{
filterChain.doFilter(servletRequest,servletResponse);
}
@Override
publicvoiddestroy(){
}
}
注册过滤器
packagecom.theeternity.beans.filterConfig;
importorg.springframework.boot.web.servlet.FilterRegistrationBean;
importorg.springframework.context.annotation.Bean;
importorg.springframework.context.annotation.Configuration;
/**
*@program:ApiBoot
*@description:注册过滤器
*@author:TheEternityZhang
*@create:2019-02-1713:10
*/
@Configuration
publicclassFilterConfig{
@Bean
publicFilterRegistrationBeanregistFilter(){
FilterRegistrationBeanregistration=newFilterRegistrationBean();
AuthFilterauthFilter=newAuthFilter();
registration.setFilter(authFilter);
registration.addUrlPatterns(authFilter.addUrlPatterns());
registration.setOrder(authFilter.order());
registration.setName("AuthFilter");
returnregistration;
}
}
SpringBoot使用拦截器
封装Interceptor
packagecom.theeternity.common.baseInterceptor;
importorg.springframework.web.servlet.HandlerInterceptor;
/**
*@program:ApiBoot
*@description:封装Interceptor
*@author:TheEternityZhang
*@create:2019-02-1517:49
*/
publicinterfaceMappingInterceptorextendsHandlerInterceptor{
String[]addPathPatterns();
String[]excludePathPatterns();
intorder();
}
自定义Interceptor
packagecom.theeternity.beans.interceptorConfig;
importcom.theeternity.common.baseInterceptor.MappingInterceptor;
importorg.springframework.stereotype.Component;
importorg.springframework.web.servlet.ModelAndView;
importjavax.servlet.http.HttpServletRequest;
importjavax.servlet.http.HttpServletResponse;
/**
*@program:BoxApi
*@description:跨域拦截器
*@author:tonyzhang
*@create:2018-12-2114:44
*/
@Component
publicclassCrossOriginInterceptorimplementsMappingInterceptor{
@Override
publicString[]addPathPatterns(){
returnnewString[]{"/**"};
}
@Override
publicString[]excludePathPatterns(){
returnnewString[0];
}
@Override
publicintorder(){
return0;
}
@Override
publicbooleanpreHandle(HttpServletRequestrequest,HttpServletResponseresponse,Objecthandler)throwsException{
logger.info("允许的头信息"+request.getHeader("Origin"));
response.setHeader("Access-Control-Allow-Origin","*");
response.setHeader("Access-Control-Allow-Methods","*");
response.setHeader("Access-Control-Max-Age","3600");
response.setHeader("Access-Control-Allow-Headers","Origin,X-Requested-With,Content-Type,Accept");
//是否允许浏览器携带用户身份信息(cookie)
response.setHeader("Access-Control-Allow-Credentials","true");
returntrue;
}
@Override
publicvoidpostHandle(HttpServletRequestrequest,HttpServletResponseresponse,Objecthandler,ModelAndViewmodelAndView)throwsException{
}
@Override
publicvoidafterCompletion(HttpServletRequestrequest,HttpServletResponseresponse,Objecthandler,Exceptionex)throwsException{
}
}
注册Interceptor
packagecom.theeternity.beans.interceptorConfig;
importorg.springframework.beans.factory.annotation.Autowired;
importorg.springframework.context.annotation.Configuration;
importorg.springframework.web.servlet.config.annotation.InterceptorRegistry;
importorg.springframework.web.servlet.config.annotation.WebMvcConfigurer;
/**
*@program:ApiBoot
*@description:拦截器注册
*@author:TheEternityZhang
*@create:2019-02-1517:55
*/
@Configuration
publicclassInterceptorConfigimplementsWebMvcConfigurer{
@Autowired
privateCrossOriginInterceptorcrossOriginInterceptor;
@Override
publicvoidaddInterceptors(InterceptorRegistryregistry){
registry.addInterceptor(crossOriginInterceptor).addPathPatterns(crossOriginInterceptor.addPathPatterns());
}
}
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持毛票票。
声明:本文内容来源于网络,版权归原作者所有,内容由互联网用户自发贡献自行上传,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任。如果您发现有涉嫌版权的内容,欢迎发送邮件至:czq8825#qq.com(发邮件时,请将#更换为@)进行举报,并提供相关证据,一经查实,本站将立刻删除涉嫌侵权内容。