最近几天稍微研究了一下过滤器和拦截器,稍微明白了一点,当然还有很多不太懂,在这里就先记录一下,省的以后忘了。
本来是想写一个拦截器,用来拦截请求到controller的request,判断request的来源来决定是否可以访问,在拦截器中还要调Dao层,获得数据库中的一些数据进行逻辑校验,但是不知道为啥,在自己电脑写好的拦截器完全好使,然后放到客户电脑就咋都不行,架构和代码几乎完全一样,但就是不好使。(ps:折磨了我好几天然并卵还是不好使,我一直觉得是客户电脑的哪里配置不好使,试图修改配置,深陷在这个坑,然后问了别人,他说,你用过滤器不行么,emmmmmmmmm说的好有道理无法反驳,只要能达到目的啥不都一样),于是乎,着手将拦截器改成过滤器。
首先,拦截器是在springmvc的文件里面配置的,然后写一个拦截器类即可,过滤器是在web.xml文件里面配置的,然后写一个过滤器类,那么,问题来了,拦截器和过滤器是个啥区别。查了一些资料,大概区别是这些:
1.拦截器只能对action(controller)请求起作用,而过滤器则可以对几乎所有的请求起作用。
2.在action的生命周期中,拦截器可以多次被调用,而过滤器只能在容器初始化时被调用一次。
这个我现在理解的意思是,action的一次生命周期,即为本次进入到controller,到controller执行结束,过滤器只是在初始化的时候根据配置文件,这么调用一次, 但是拦截器应该是可以当做正常的类使用,在controller中可以实例化拦截器类,作为一个对象使用。
3.拦截器可以获取IOC容器中的各个bean,而过滤器就不行,这点很重要,在拦截器里注入一个service,可以调用业务逻辑。
拦截器可以是用@Autowired 依赖注入的标签,注入service,dao等等,进行逻辑实现,但是过滤器不可以,用这个标签的话,拿到的对象为空,需要用手动调用方法,调用service,dao等。
在 过滤器中如果想调用dao,service 的话,代码如下:
public class TextFilter implements Filter{
private PersonDAO personDao;
@override
public void init(FilterConfig filterConfig) trrows ServletException
ApplicationContext context = WebApplicationContextUtils.getWebApplicationContext(filterConfig.getServletContext());
PersonDAO bean = context.getBean(PersonDAO.class);
this.personDao = bean;
}
然后下面用personDao调用即可。
4.拦截器可以访问action上下文、值栈里的对象,而过滤器不能访问。
和2 3 道理应该差不多
5.拦截器是基于java的反射机制的,而过滤器是基于函数回调。
JAVA反射机制是在运行状态中,对于任意一个实体类,都能够知道这个类的所有属性和方法;对于任意一个对象,都能够调用它的任意方法和属性;这种动态获取信息以及动态调用对象方法的功能称为java语言的反射机制。
6.拦截器不依赖与servlet容器,过滤器依赖与servlet容器。
大概就这些,以后可能再更新。