拦截器:interceptor
过滤器:filter
拦截器和过滤器的区别:
1、拦截器是基于java的反射机制,过滤器是基于函数回调
2、拦截器不依赖于servlet容器,过滤器依赖于servlet容器
3、拦截器只能对action请求起作用,过滤器则几乎可以对所以的请求起作用
4、拦截器可以访问action上下文、值栈里的对象,过滤器不行
5、在action的生命周期里,拦截器可以多次被调用,过滤器只能在容器初始化的时候被调用一次
6、拦截器可以获取IOC(控制反转 Inversion of Control)容器中的各个bean,过滤器不行,这点很重要,在拦截器里面注入一个service可以调用业务逻辑
例:
APIAuthInterceptor.java:
public class APIAuthInterceptor extends HandlerInterceptorAdapter {
private static final Logger logger = LoggerFactory.getLogger(APIAuthInterceptor.class);
//引入service注解
@ServiceAutowired
private ITokenHandlerService tokenHandlerService;
public void setTokenHandlerService(ITokenHandlerService tokenHandlerService) {
this.tokenHandlerService = tokenHandlerService;
}
public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) throws Exception {
//获取token控制的系统参数,1表示token开启,要拦截,0表示关闭,直接通过
String tokenSwitch = tokenHandlerService.getTokenSwitch();
return super.preHandle(request, response, handler);
}
public void postHandle(HttpServletRequest request, HttpServletResponse response, Object handler, ModelAndView modelAndView)
throws Exception {
super.postHandle(request, response, handler, modelAndView);
}
拦截器配置:
<mvc:interceptors>
<mvc:interceptor>
<mvc:mapping path="/**" />
<bean class="com.lcl.token.service.APIAuthInterceptor" >
<property name="tokenHandlerService">
<ref bean="tokenHandlerService"/>
</property>
</bean>
</mvc:interceptor>
</mvc:interceptors>
拦截器里面要引入service注解,要先在xml文件配置service
<bean id="tokenHandlerService" class="com.lcl.token.service.TokenHandlerServiceImpl"></bean>