JAVA过滤器(Filter)

一.Filter的简介

filter是对客户端访问资源的过滤,符合条件放行,不符合条件不放行,并且可以对目标资源访问前后进行逻辑处理

作用:

  • 代码的抽取(可以对request设置编码,这样所有走过的servlet的编码都是统一的,没必要每一个都写)
  • 权限管理(在filter内部取出当前登录用户的角色,再看访问的资源,如果匹配则放行,不匹配则不放行)
     

二.Filter详解

Filter生命周期及其与生命周期相关的方法

Filter接口有三个方法,并且这个三个都是与Filter的生命相关的方法 

  • init(Filterconfig):代表filter对象初始化方法,filter对象创建时执行
  • doFilter(ServletRequest,ServletResponse,FilterCha):代表filter执行过滤的核心方法,如果某资源在已经被配置到这个filter进行过滤的话,那么每次访问这个资源都会执行doFilter方法
  • destory():代表是filter销毁方法,当filter对象销毁时执行该方法

Filter对象的生命周期: 

  • Filter何时创建:服务器启动时就创建该filter对象
  • Filter何时销毁:服务器关闭时filter销毁
  • 每次访问被filter过滤的资源时,都执行doFilter()

Filter的API详情

init(FilterConfig arg0)其中参数arg0代表该Filter对象的配置信息的对象,内部封装是该filter的配置信息。

@Override
public void init(FilterConfig arg0) throws ServletException {
    //获得web.xml中<filter-name>QuickFilter1</filter-name>的名字
    System.out.println(arg0.getFilterName());
    //获得当前filter的初始化参数<init-param><param-name>aaa</param-name><param-value>bbb</param-value></init-param>
    System.out.println(arg0.getInitParameter("aaa"));
    //获得所有初始化参数的名字
    System.out.println(arg0.getInitParameterNames());
    //获得servletContext对象(故先有servletContext)
    System.out.println(arg0.getServletContext());
    System.out.println("init...");
}

destory()方法在filter对象销毁时执行

doFilter(ServletRequest arg0,ServletResponse arg1,FilterChain arg2)方法时Filter的核心过滤方法,参数解析如下: 

  • ServletRequest arg0:内部封装的是客户端http请求的内容
  • ServletResponse arg1:代表响应
  • ServletRequest/ServletResponse:每次在执行doFilter方法时 web容器负责创建一个request和一个response对象作为doFilter的参数传递进来。该request给该response就是在访问目标资源的service方法时的request和response。
  • FilterChain:过滤器链对象,知道所有filter和对应的顺序,通过该对象的doFilter方法可以放行该请求 【注意filter的顺序是根据filter-mapping的先后顺序去执行】

过滤链

web.xml中可定义多个过滤器,过滤器的过滤顺序和web.xml中filter的定义顺序相同。每次调用FilterChain对象的doFilter()方法,servlet容器会检查FilterChain对象中是否还有Filter,如果有接着过滤;如果没有则进入接口操作资源

Filter的配置

<filter>
  <filter-name>QuickFilter1</filter-name>
  <filter-class>filter.QuickFilter1</filter-class>
  <init-param>
      <param-name>aaa</param-name>
      <param-value>bbb</param-value>
  </init-param>
</filter>
<filter-mapping>
  <filter-name>QuickFilter1</filter-name>
  <url-pattern>/*</url-pattern>
  <dispatcher>REQUEST</dispatcher><!-- 直接访问某个资源时执行filter -->
</filter-mapping>
<filter>
  <filter-name>QuickFilter2</filter-name>
  <filter-class>filter.QuickFilter2</filter-class>
</filter>
<filter-mapping>
  <filter-name>QuickFilter2</filter-name>
  <url-pattern>/*</url-pattern>
  <dispatcher>FORWARD</dispatcher><!-- 转发时才执行filter -->
</filter-mapping>

配置项说明:

<filter>中配置项:

    <filter-name>:过滤器的名称

    <filter-class>:该过滤器对应的配置类

    <inti-param>:初始化参数

    <param-name>:参数名称

    <param-value>:参数值 

<filter-mapping>中配置项:

    <filter-name>:过滤器名称,和<filter>中的<filter-name>相同

    <url-pattern>:过滤器过滤的资源路径

    <dispatcher>:指定过滤器过滤的资源的调用方式,默认为REQUEST

url-pattern配置

  • 完全匹配 /sertvle1
  • 目录匹配 /aaa/bbb/* (最多的)
  • /user/*:访问前台的资源进入此过滤器
  • /admin/*:访问后台的资源时执行此过滤器
  • 扩展名匹配 .abc .jsp

注意:url-pattern可以使用servlet-name替代,也可以混用,表示过滤指定的servlet。

dispatcher:访问的方式

  • REQUEST:默认值,代表直接访问某个资源时执行filter(故此时转发访问一次,重定向访问两次)
  • FORWARD:转发时才执行filter
  • INCLUDE: 包含资源时执行filter(A资源包含B资源的情形下执行)
  • ERROR:发生错误时进行跳转是执行filter(在跳转错误页面的时候执行)
     

猜你喜欢

转载自blog.csdn.net/qq_42239765/article/details/90545916