zoukankan      html  css  js  c++  java
  • 黑马day14 过滤器概述&生命周期&运行过程

    过滤器:当訪问一个web资源的时候,过滤器就在你訪问这个web资源的前进行拦截...在放行过后...filter过滤器也能够做一些其它的事情.

    编写过滤器的步骤:

    1.写一个过滤器类实现filter接口

    2.在web.xml文件里进行注冊..

    案例1:

    (1).过滤器类

    package cn.itheima.filter;
    
    import java.io.IOException;
    
    import javax.servlet.Filter;
    import javax.servlet.FilterChain;
    import javax.servlet.FilterConfig;
    import javax.servlet.ServletException;
    import javax.servlet.ServletRequest;
    import javax.servlet.ServletResponse;
    
    public class FilterDemo1 implements Filter {
    	//过滤器初始化的时候调用这种方法
    	public void init(FilterConfig filterConfig) throws ServletException {
    		System.out.println("init....");
    	}
    	public void doFilter(ServletRequest request, ServletResponse response,
    			FilterChain chain) throws IOException, ServletException {
    		System.out.println("过滤....");
    		//放行
    		chain.doFilter(request, response);
    	}
    	//过滤器对象死亡的时候做的善后工作
    	public void destroy() {
    		System.out.println("destory....");
    	}
    
    }
    
    (2).web.xml文件里的配置:

    <filter>
      	<filter-name>FilterDemo1</filter-name>
      	<filter-class>cn.itheima.filter.FilterDemo1</filter-class>
      </filter>
      <filter-mapping>
      	<filter-name>FilterDemo1</filter-name>
      	<url-pattern>/*</url-pattern>
      </filter-mapping>
    (3).编写一个servlet进行測试:

    package cn.itheima.servlet;
    
    import java.io.IOException;
    
    import javax.servlet.ServletException;
    import javax.servlet.http.HttpServlet;
    import javax.servlet.http.HttpServletRequest;
    import javax.servlet.http.HttpServletResponse;
    
    public class FilterDemo1 extends HttpServlet {
    
    	public void doGet(HttpServletRequest request, HttpServletResponse response)
    			throws ServletException, IOException {
    		response.getWriter().write("Hello world!");
    	}
    
    	public void doPost(HttpServletRequest request, HttpServletResponse response)
    			throws ServletException, IOException {
    		doGet(request, response);
    	}
    
    }
    
    执行结果:

    当我们启动tomcat的时候,载入day14应用完成的时候init方法运行....

    当我们訪问FilterDemo1的时候....假设放行即有doFilter()...就会在页面中看到hello world的字样。

    假设没有放行。就不会看到...

    当关闭tomcat的时候。我们发现destory方法运行....

    因此我们能够总结出filter的生命周期:

    生命周期:

    当server启动时,web应用载入后,马上创建这个web应用中的全部的过滤器,过滤器创建出来后马上调用init方法运行初始化的操作.
    创建出来后一直驻留在内存中为兴许的拦截进行服务.每次拦截到请求后都会导致doFilter方法运行.
    在server关闭或web应用被移除出容器时,随着web应用的销毁过滤器对象销毁.销毁之前调用destory方法运行善后工作.
    案例2:

    (1).我们写两个过滤器FilterDemo1和FilterDemo2

    package cn.itheima.filter;
    
    import java.io.IOException;
    
    import javax.servlet.Filter;
    import javax.servlet.FilterChain;
    import javax.servlet.FilterConfig;
    import javax.servlet.ServletException;
    import javax.servlet.ServletRequest;
    import javax.servlet.ServletResponse;
    
    public class FilterDemo1 implements Filter {
    	//过滤器初始化的时候调用这种方法
    	public void init(FilterConfig filterConfig) throws ServletException {
    	}
    	public void doFilter(ServletRequest request, ServletResponse response,
    			FilterChain chain) throws IOException, ServletException {
    		System.out.println("filterDemo1....before");
    		chain.doFilter(request, response);
    		System.out.println("filterDemo1....after");
    	}
    	//过滤器对象死亡的时候做的善后工作
    	public void destroy() {
    	}
    
    }
    


    package cn.itheima.filter;
    
    import java.io.IOException;
    
    import javax.servlet.Filter;
    import javax.servlet.FilterChain;
    import javax.servlet.FilterConfig;
    import javax.servlet.ServletException;
    import javax.servlet.ServletRequest;
    import javax.servlet.ServletResponse;
    
    public class FilterDemo2 implements Filter {
    
    	public void init(FilterConfig filterConfig) throws ServletException {
    	}
    
    	public void doFilter(ServletRequest request, ServletResponse response,
    			FilterChain chain) throws IOException, ServletException {
    		System.out.println("filterDemo2....before");
    		chain.doFilter(request, response);
    		System.out.println("filterDemo2....after");
    	}
    
    	public void destroy() {
    	}
    
    }

    控制台的打印结果是:

    filterDemo1....before
    filterDemo2....before
    filterDemo2....after
    filterDemo1....after

    过滤器的运行顺序是依据web.xml文件里的mapping的配置顺序运行的。

    同一时候init的方法还能够使用filterConfig来获取配置文件里的信息。这里我就不演示了


  • 相关阅读:
    tensorflow2知识总结---3、逻辑回归与交叉熵
    tensorflow2知识总结---2、多层感知器实例
    日常英语---200720(感知器:perceptron)
    日常英语---200720(numpy怎么读)
    日常英语---200720(tensorflow2优化函数:model.compile(optimizer='adam',loss='binary_crossentropy',metrics=['acc']))
    tensorflow2知识总结---1、线性回归实例
    Guid.ToString Method
    Intercept HTTP requests
    Fetch API
    古墓惊魂 关卡奖励的宝藏
  • 原文地址:https://www.cnblogs.com/wzjhoutai/p/7069338.html
Copyright © 2011-2022 走看看