day09

过滤器

1.过滤器介绍

1.1 什么是过滤器

JavaWeb中的过滤器的概念: 对请求响应进行拦截或者增强的对象,就是过滤器。(重点

JavaWeb中的过滤器是什么呢?
Filter接口:功能——对请求响应进行增强,或者进行拦截。

day09_第1张图片
图片22.png
1.2 JavaWEB中的过滤器运行图解(重点)
day09_第2张图片
图片23.png

第2章 Filter的快速入门(重点:必须掌握

2.1 Filter定义以及创建步骤介绍

定义一个过滤器:

  • 第一步:创建一个类,实现过滤器接口
  • 第二步:具体需要执行的过滤任务,写在doFilter
  • 第三步:过滤器需要在web.xml中配置

代码演示:

public class MyFilter implements Filter{

    /**
     * 初始化方法
     * */
    @Override
    public void init(FilterConfig filterConfig) throws ServletException {
        // TODO Auto-generated method stub
    }

    /**
     * 执行过滤任务的方法
     * */
    @Override
    public void doFilter(ServletRequest request, ServletResponse response,
            FilterChain chain) throws IOException, ServletException {
        System.out.println("MyFilter....doFilter.....");
        
    }
    /**
     * 销毁的方法
     * */
    @Override
    public void destroy() {
        // TODO Auto-generated method stub
    }

}

Filter 是在 Web 应用程序的部署描述符中配置的——过滤器创建好之后,需要在web.xml中做配置

2.2Filter拦截操作效果
day09_第3张图片
图片24.png

总结:过滤放行,全靠它

FilterChain的doFilter方法:


day09_第4张图片
图片25.png

代码实现:

day09_第5张图片
图片26.png

效果:

过滤器放行执行过程:

day09_第6张图片
图片27.png

第3章 Filter生命周期

3.1 Filter生命周期

回顾servlet的生命周期:
创建: 第一次被访问的时候
销毁: 服务器关闭的时候,或者当前项目从服务器中移除

回顾session的生命周期:
创建: 第一次调用getsession方法,第一次访问jsp
销毁: 服务器非正常关闭,超过生存时间,调用销毁(自杀)的方法

Filter:
创建:在服务器启动的时候
销毁: 在服务器关闭的时候,过滤器销毁。

服务器启动截图:


day09_第7张图片
图片28.png

服务器关闭截图:


day09_第8张图片
图片29.png

第4章 FilterConfig介绍

servletConfig对象:获取servlet相关的配置信息。

FilterConfig定义:获取filter相关的配置信息。


day09_第9张图片
图片30.png

API介绍:


day09_第10张图片
图片31.png

API代码演示:

1)设置过滤器初始化参数
2)通过filterconfig对象来获取参数


day09_第11张图片
图片32.png

参数配置:


    MyFilter
    cn.igeek.filter.MyFilter
    
        haha
        哈哈
    
    
        heihei
        嘿嘿
    
  
  
  
    MyFilter
    /1.txt
  

效果演示:

day09_第12张图片
图片33.png

第5章 Filter配置详解(web.xml中的配置)(重点

5.1 关于url-pattern配置

过滤器如何匹配请求的路径?

回顾servlet的url-pattern:
全路径匹配——
地址栏:localhost:8080/项目根路径/资源路径 localhost:8080/igeek-filter2/1.txt
通配符的匹配——
地址栏:localhost:8080/项目根路径/abc/*

以上两种匹配方式,配置路径的时候必须以”/”开头


day09_第13张图片
图片34.png

后缀名匹配—— *.do: *.do *.txt .action
地址栏:localhost:8080/项目根路径/
.txt
后缀名匹配方式,配置路径的时候不能以”/”开头

Filter的url-pattern配置与servlet一致。

过滤器的执行顺序?

测试方式:
1)两个过滤器,拦截同一个请求
2)调整两个过滤器的配置,再来看执行的顺序

路径/*的优先级最高
urlParam 优先>ServletName 配置路径相同的 字母在前的优先

总结:
过滤器执行的顺序是按照,web.xml中filter-mapping标签的书写顺序执行(从上往下执行)

5.2 关于servlet-name配置
什么是servlet-name配置?
定义:针对指定的servlet进行拦截或者增强操作的配置

Servlet:省略

@WebFilter(urlPatterns={ "/MyFilter2", "/*" },
            initParams={@WebInitParam(name="company",value="igeek"),
                        @WebInitParam(name="address",value="wuhan")
                        })
public class MyFilter2 implements Filter {

    /**
     * Default constructor. 
     */
    public MyFilter2() {
        // TODO Auto-generated constructor stub
    }

    /**
     * @see Filter#destroy()
     */
    public void destroy() {
        // TODO Auto-generated method stub
    }

    /**
     * @see Filter#doFilter(ServletRequest, ServletResponse, FilterChain)
     */
    public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
        // TODO Auto-generated method stub
        // place your code here
        System.out.println("MyFilter2-------过滤器2");
        // pass the request along the filter chain
        chain.doFilter(request, response);
    }

    /**
     * @see Filter#init(FilterConfig)
     */
    public void init(FilterConfig fConfig) throws ServletException {
        System.out.println("过滤器的名称:"+fConfig.getFilterName());
        System.out.println("公司名称:"+fConfig.getInitParameter("company"));
        Enumeration params=fConfig.getInitParameterNames();
        while(params.hasMoreElements()){
            String param=params.nextElement();
            System.out.println(param+":"+fConfig.getInitParameter(param));
        }
        System.out.println(fConfig.getServletContext());
    }

}
day09_第14张图片
无标题.png

你可能感兴趣的:(day09)