遇到问题后我并没有慌张,而是回忆了一下过滤器的知识:
1.过滤器执行顺序是从web.xml定义的filter标签顺序从上到下执行
2.过滤器里的doFilter方法有个参数filterChain,这个参数指的是过滤链,因为多个过滤器执行其实是因为每个过滤器调用了这个方法,如果某个过滤器doFilter中没有执行这个方法,那么请求就不会走剩下的过滤器。
所以明白这几点后,我果断把自定义的过滤器提到了web.xml中第一个filter标签的位置,重新启动,再次发送请求,不出意外的请求进入了过滤器并执行了doFilter方法,而之前没有走过滤器的原因是位于自定义过滤器前的某个过滤器在执行doFilter方法时并没有调用filterChain的doFilter方法,所以造成了自定义过滤器没有执行,至于是哪个过滤器导致的,并不关心。
最后普及一下之前提到的doFilter的问题,首先Filter接口有一个方法叫doFilter,他的意思是当过滤器有匹配的请求被拦截时会进入这个方法,而这个方法有三个参数,其中两个个是request和response,剩下的一个是filterChain,filterChain有一个方法doFilter,他又两个参数request和response,当执行filterChain的doFilter方法时,请求会走入下一个过滤器,如果不执行的话就会跳过剩余的过滤器继续他的旅程。