一.过滤器Filter的使用
- 第一步:编写一个类实现Filter接口
public class FilterTest implements Filter
- 第二步: 对过滤器在web.xml中进行配置注册
<!-- 注册过滤器Filter -->
<!--
<description>用于添加描述信息,该元素的内容可为空,<description>可以不配置。
<filter-name>用于为过滤器指定一个名字,该元素的内容不能为空。
<filter-class>元素用于指定过滤器的完整的限定类名。
<init-param>元素用于为过滤器指定初始化参数,它的子元素<param-name>指定参数的名字,<param-
value>指定参数的值。在过滤器中,可以使用FilterConfig接口对象来访问初始化参数。如果过滤
器不需要指定初始化参数,那么<init-param>元素可以不配置.
-->
<filter>
<description>过滤器名称</description>
<filter-name>自定义的名字</filter-name>
<filter-class>com.yangcq.filter.FilterTest</filter-class>
<!--配置FilterTest过滤器的初始化参数-->
<init-param>
<description>配置过滤器的初始化参数</description>
<param-name>name</param-name>
<param-value>gacl</param-value>
</init-param>
<init-param>
<description>配置FilterTest过滤器的初始化参数</description>
<param-name>like</param-name>
<param-value>java</param-value>
</init-param>
</filter>
<!-- 映射过滤器Filter -->
<!--
<filter-mapping>元素用于设置一个 Filter 所负责拦截的资源。
一个Filter拦截的资源可通过两种方式来指定:Servlet 名称和资源访问的请求路径,前者比较少用
<filter-name>子元素用于设置filter的注册名称。该值必须是在<filter>元素中声明过的过滤器的名字
<url-pattern>设置 filter 所拦截的请求路径(过滤器关联的URL样式)
完全路径匹配 :以/开始 比如/aaa /aaa/bbb
目录匹配 :以/开始 以*结束 比如/* /aaa/* /aaa/bbb/*
扩展名匹配 :不能以/开始 以*开始 比如*.jsp *.do *.action
<servlet-name>指定过滤器所拦截的Servlet名称。很少用
<dispatcher> 可以取值
REQUEST :默认值。默认过滤器拦截的就是请求。直接访问页面时,请求转发不会
FORWARD :转发。 通过请求转发时,要想请求和请求转发都拦截,则需和REQUEST都配置
INCLUDE :页面包含的时候进行拦截 通过RequestDispatcher的include()方法访问时
ERROR :页面出现全局错误页面跳转的时候进行拦截 通过声明式异常处理机制调用时
-->
<filter-mapping>
<filter-name>FilterTest</filter-name>
<url-pattern>/*</url-pattern> <!--“/*”表示拦截所有的请求 -->
<dispatcher>REQUEST</dispatcher>
<dispatcher>FORWARD</dispatcher>
</filter-mapping>
二.过滤器的生命周期
Filter的创建和销毁是由web服务器负责。Web应用程序启动的时候,web服务器创建Filter的实例对象。并调用其init方法进行初始化(filter对象只会创建一次,init方法也只会执行一次)。
每次filter进行拦截的时候,都会执行doFilter的方法。
当服务器关闭的时候,应用从服务器中移除的时候,服务器会销毁Filter对象。