过滤器

过滤器简介


1)过滤器其实就是一个接口,Filter, javax.servet.Filter


2)过滤器就是一个对象,可以在请求一个资源(静态或动态资源),或响应一个资源,或请求和响应一个资源的时候,执行过滤任务!!!!


3)过滤器如何被执行?


过滤器也需要交给tomcat服务器运行!!!!



Servlet的三大组件:1)都需要交给web服务器运行  2)在web.xml文件中配置 

Servlet接口

Filter接口



4)过滤器的

生命周期


构造方法: 在web应用加载时创建过滤器对象。只执行一次。证明过滤器在web服务器中是单实例的


init方法: 在创建完过滤器对象之后被调用。只执行一次


doFilter方法: 执行过滤任务方法。执行多次。


destroy方法: web服务器停止或者web应用重新加载,销毁过滤器对象。


5)过滤器编写步骤:


5.1 编写一个java类,实现Filter接口,并实现其中的所有方法


5.1 在web.xml文件中配置Filter

<!-- 过滤器配置 -->
	<filter>
		<!-- 内部名称 -->
		<filter-name>HelloFilter</filter-name>
		<!-- 类全名:包+简单类名 -->
		<filter-class>gz.itcast.a_hello.HelloFilter</filter-class>
	</filter>
	<!-- 过滤器映射配置 -->
	<filter-mapping>
		<!-- 内部名称,和上面的名称保持一致! -->
		<filter-name>HelloFilter</filter-name>
		<!-- 需要拦截的路径 -->
		<url-pattern>/hello</url-pattern>
	</filter-mapping>

过滤器的映射路径


过滤器中的url-pattern: 表示的这个过滤器需要拦截的目标资源路径(可以servlet路径,也可以是静态资源名称)


Servlet中的url-pattern: 表示访问这个servlet时的路径



url-pattern                       浏览器访问目标资源的路径



精确过滤                    /hello                             http://localhost:8080/day21/hello


/itcast/hello                     http://localhost:8080/day21/itcast/hello




模糊过滤                      /*                                  http://localhost:8080/day21/任意路径


/itcast/*

 http://localhost:8080/day21/itcast/任意路径


*.后缀名

 http://localhost:8080/day21/任意路径.后缀名




注意:


1)url-pattern要么以斜杠开头,要么以*开头  例如: hello


2)不能同时使用两个模糊过滤。例如 /*.do 是非法的


3)如果存在多个需要被过滤的资源,可以写多个url-pattern去过滤。


4)如果是动态资源servlet,可以使用servlet的访问名称,也可以使用内部名称

<!-- 使用servlet的内部名称 -->
		<servlet-name>HelloServlet</servlet-name>

        5)过滤类型:

<!-- 过滤类型:声明哪种请求才可以被拦截(过滤) -->
		<dispatcher>REQUEST</dispatcher><!-- 默认:来自于直接访问的请求才可以被拦截 -->
		<dispatcher>FORWARD</dispatcher><!-- 来自于转发的请求才可以被拦截 -->
		<dispatcher>INCLUDE</dispatcher><!-- 来自于包含的请求才可以被拦截 -->
		<dispatcher>ERROR</dispatcher><!-- 来自于错误的请求才可以被拦截 -->

FilterConfig对象

    FilterConfig对象,过滤器配置对象,用于加载过滤器的参数配置


过滤器参数使用:

1)在web.xml文件中配置

<!-- 过滤器配置 -->
	<filter>
		<!-- 内部名称 -->
		<filter-name>HelloFilter</filter-name>
		<!-- 类全名:包+简单类名 -->
		<filter-class>gz.itcast.a_hello.HelloFilter</filter-class>
		<init-param>
			<param-name>AAA</param-name>
			<param-value>AAA'value</param-value>
		</init-param>
		<init-param>
			<param-name>BBB</param-name>
			<param-value>BBB'value</param-value>
		</init-param>
	</filter>

2)在过滤器器中使用

/**
	 * 2)init初始化方法
	 */
	public void init(FilterConfig filterConfig) throws ServletException {
		System.out.println("2)Filter生命周期-init方法");
		
		/**
		 * 通过FilterConfig对象得到参数配置信息
		 */
		//得到一个参数
		System.out.println(filterConfig.getInitParameter("AAA"));
		
		Enumeration<String> enums = filterConfig.getInitParameterNames();
		//遍历所有参数
		while(enums.hasMoreElements()){
			String paramName = enums.nextElement();
			String paramValue = filterConfig.getInitParameter(paramName);
			System.out.println(paramName+"="+paramValue);
		}
		
	}