容器在加载的时候,会读取web.xml中的<filter></filter>,根据指定的类路径来实例化过滤器。
那么过滤器究竟是用来做什么的呢?
顾名思义,过滤器肯定是过滤我们不想要的东西。所以说执行肯定是在我们访问某个页面之前。所以发散开来,它也可以执行一些我们在访问某个页面,或者某些页面之前想要的操作。
那么:
a.什么是过滤器?过滤器和普通类有什么区别?
b.过滤器中的chain.doFilter()起什么作用?
所以说chain.doFilter(request,response)是过滤器的必要操作,目的是如果有多个过滤器需要处理同一个url时把请求传给下一个过滤器。
c.过滤器的处理的先后顺序?
<servlet-mapping>
<servlet-name>myServlet</servlet-name>
<url-pattern>/foo*</url-pattern>
</servlet-mapping>
<filter-mapping>
<filter-name>servletFilter</filter-name>
<url-pattern>myServlet</url-pattern>
</filter-mapping>
<filter-mapping>
<filter-name>myFilter</filter-name>
<url-pattern>/foo*</url-pattern>
</filter-mapping>
<filter-mapping>
<filter-name>anotherFilter</filter-name>
<url-pattern>/foo/bar</url-pattern>
</filter-mapping>
如果一个普通的请求访问的URL是/foo/bar,那么它将匹配所有这3个过滤器。过滤器链将由3个过滤器组成,依次为myFilter、anotherFilter,然后是servletFilter。myFilter将在anotherFilter之前执行,因为这是它们出现在部署描述符中的顺序。它们都将在servletFilter之前执行,因为URL映射总是在Servlet名称映射之前执行。
参考自:https://www.cnblogs.com/deepSleeping/p/9609809.html