web过虑器
一、过虑器定义
过虑器是一个服务端实现javax.servlet.Filter接口的java类,它可以截取用户端的请求与服务端的响应信息,实现对这些信息过虑。可以实现以下目的:
1. 在客户端的请求访问后端资源之前,拦截这些请求。
2. 在服务器的响应发送回客户端之前,处理这些响应。
二、工作原理
三、过虑器配置与生命周期
实例化 web.xml 初始化 init() 过虑 doFilter() 销毁 destroy()
web.xml配置各节点说明
<filter> 指定一个过滤器。 <filter-name> 用于为过滤器指定一个名字,该元素的内容不能为空。 <filter-class> 元素用于指定过滤器的完整的限定类名。 <init-param> 元素用于为过滤器指定初始化参数,它的子元素<param-name>指定参数的名字,<param-value>指定参数的值。在过滤器中,可以使用FilterConfig接口对象来访问初始化参数。 <filter-mapping> 元素用于设置一个 Filter 所负责拦截的资源。一个Filter拦截的资源可通过两种方式来指定:Servlet 名称和资源访问的请求路径 <filter-name> 子元素用于设置filter的注册名称。该值必须是在<filter>元素中声明过的过滤器的名字 <url-pattern> 设置 filter 所拦截的请求路径(过滤器关联的URL样式) <servlet-name> 指定过滤器所拦截的Servlet名称。
例子:
public class LoginFilter implements Filter { public void destroy() { } public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException { // place your code here // pass the request along the filter chain chain.doFilter(request, response); } public void init(FilterConfig fConfig) throws ServletException { } }
web.xml配置
<filter> <filter-name>LoginFilter </filter-name> <filter-class>com.ittx.test.LoginFilter </filter-class> <init-param> <param-name>test-param</param-name> <param-value>Initialization Paramter</param-value> </init-param> </filter> <filter> <filter-name>AuthenFilter</filter-name> <filter-class>com.ittx.test.AuthenFilter</filter-class> <init-param> <param-name>test-param</param-name> <param-value>Initialization Paramter</param-value> </init-param> </filter> <filter-mapping> <filter-name>LoginFilter </filter-name> <url-pattern>/*</url-pattern> </filter-mapping> <filter-mapping> <filter-name>AuthenFilter</filter-name> <url-pattern>/*</url-pattern> </filter-mapping>
四、过虑链
一个web请求可以定义多个过虑器,它们按先后顺序组装在一起成为一条过虑链.
五、过虑器分类
REQUEST:当用户直接访问页面时,Web容器将会调用过滤器。如果目标资源是通过RequestDispatcher的include()或forward()方法访问时,那么该过滤器就不会被调用。
INCLUDE:如果目标资源是通过RequestDispatcher的include()方法访问时,那么该过滤器将被调用。除此之外,该过滤器不会被调用。
FORWARD:如果目标资源是通过RequestDispatcher的forward()方法访问时,那么该过滤器将被调用,除此之外,该过滤器不会被调用。
ERROR:如果目标资源是通过声明式异常处理机制调用时,那么该过滤器将被调用。除此之外,过滤器不会被调用。
在web.xml中配置
指定过滤器所拦截的资源被 Servlet 容器调用的方式,可以是REQUEST,INCLUDE,FORWARD和ERROR之一,默认REQUEST。用户可以设置多个子元素用来指定 Filter 对资源的多种调用方式进行拦截。
web监听器参见:如何使用监听器Servlet
转载请注明来源:web过虑器