一、Filter

  1、 Filter简介

    > Filter翻译为中文是过滤器的意思。

    > Filter是JavaWeb的三大web组件之一:Servlet、Filter、Listener

    > Filter的作用是在请求到达WEB资源(HTML、CSS、Servlet、JSP)之前进行拦截。

    > Filter需要交给Tomcat访问器来管理

  2、 Filter的作用:

      1.Filter可以在请求到达目标资源之前进行拦截

      2.Filter也可以放行请求

      3.Filter可以在响应到达浏览器之前做一个预处理

  3、 Filter的创建步骤

      1.创建一个类实现Filter接口

      2.在web.xml文件中对Filter进行配置

        <filter>

          <filter-name>Filter的别名</filter-name>

          <filter-class>Filter的全类名</filter-clas

        </filter>

        <filter-mapping>

          <filter-name>别名</filter-name>

          <url-pattern>需要Filter拦截的资源地址</url-pattern>

        </filter-mapping>

  4、 Filter的生命周期

      > 一个请求的发送,到响应返回是一个线程。

      > Filter的生命周期,指的是Filter对象由被创建到被销毁的过程。

    > Filter的生命周期方法:

        - 构造器:Filter的构造器在服务器启动时调用。 构造器只会调用一次,说明Filter也是单例多线程的。

        - init():在构造器被调用后,紧接着被调用。作用:用来初始化Filter。

        - doFilter():每一次拦截请求时都会调用。

            参数

              ServletRequest request

                > 请求报文

              ServletResponse response

                > 响应报文

              FilterChain chain

                > 该对象的作用就是放行请求:

            可以通过 chain.doFilter(request,response) 放行请求。

            当调用chain.doFilter()就相当于调用目标的资源的service方法。

        - destroy方法在项目停止时调用,用来在对象被销毁前做一些收尾工作。

  5、url-pattern的设置规则:

      1.精确匹配:只有当目标资源的地址和url-pattern的地址一模一样时,Filter才会拦截资源

            例子:/2.jsp , 只有当浏览器访问项目根目录下的2.jsp时,才会调用Filter

      2.路径匹配:当访问的资源在url-pattern配置的路径下时,Filter就会拦截资源。

            例子1:/hello/* , 只要访问项目根目录下hello下的资源,就会调用Filter。

            例子2:/* , 会拦截项目根目录下所有资源

      3.后缀匹配:只要访问的资源地址和url-pattern的后缀一样就会调用Filter

            例子:*.jsp 只要是以jsp结尾的请求都会拦截

      - 以上规则适用于Servlet的url-pattern配置

    - 当使用Filter拦截一个Servlet时,可以将Filter的url-pattern和Servlet的url-pattern一样这样Filter就会拦截发送到Servlet的请求。

    - 也可以通过在filter-mapping中添加一个servlet-name标签来设置要拦截的Servlet的name

  6、Filter的执行顺序

      > 我们可以为一个资源设置多个过滤器,

      当我们为一个资源设置了多个过滤器时,这些过滤器就组成一个Filter链的结构。

      当我们去调用chain.doFilter(),如果该过滤器后边还有其他的过滤,

      相当于调用了下一个过滤器doFilter()方法

      如果过滤器后没有其他的过滤器,我们调用chain.doFilter()

      相当于调用了目标资源的service()方法。

  > 多个Filter的执行顺序,有filter-mapping标签的配置顺序决定,

      filter-mappint靠前,则filter先执行,靠后则后执行。

  > 我们可以通过修改filter-mapping的顺序来修改Filter的执行顺序,

  7、 登录练习

      1. 创建一个登录页面login.jsp

      2. 创建一个登录成功页面login-success.jsp

      3. 创建一个UsernameFilter,来检查用户的用户名是否正确,默认用户名为admin。

        - UsernameFilter要对哪个资源进行过滤?

          - 对login-success.jsp的请求进行过滤

            检查用户名是否为admin

              如果是admin,则放行

              否则直接转发回登录页面。

      4. 创建一个PasswordFilter,用来检查用户的密码是否正确,密码为123123.

        - 拦截发送给login-success.jsp

          - 获取用户填写的密码

            判断密码是否为123123

              如果是123123

                则放行

              否则直接转发回登录页面。

  8、 HttpFilter

    仿写HttpFilter,仿写和HttpServlet一致!

  9、 dispatcher

    > Filter默认只会拦截直接向目标资源发送的请求,而像转发之类的请求不会拦截

    > 可以在在filter-mapping的dispatcher标签中来指定过滤器要拦截的请求类型:

    <dispatcher>REQUEST</dispatcher>

    代表拦截发送到目标资源的直接请求,如果不指定dispatcher默认值就是request

    如果在filter-mapping设置了dispatcher则按照设置的内容来

    <dispatcher>FORWARD</dispatcher>

        FORWARD代表会拦截通过转发访问目标资源的请求。

    <dispatcher>INCLUDE</dispatcher>

        INCLUDE会拦截通过动态包含访问目标资源的请求。

    <dispatcher>ERROR</dispatcher>

        ERROR是拦截在web.xml中声明的错误页面的

      - 我们可以在web.xml文件进行一个错误页面的映射,通过如下标签:

        <error-page>

          <error-code>404</error-code>

          <location>/4.jsp</location>

        </error-page>

      error-code指的是发生错误的代码

      location 发生错误以后去到的页面

  10、 EncodingFilter。

      - 项目开发完毕以后,发现项目中出现请求乱码的问题。

      - 这个问题解决起来还是很简单,只需要在第一次使用request.getParamter()时调用request.setCharacterEncoding("utf-8");即可。

      - 但是这行代码实际在大部分servlet中都需要调用。

      - 统一来解决post请求乱码的问题?

      - 创建一个Filter用来过滤所有请求,在Filter将request的编码设置为utf-8,然后在放行请求。

05-18 22:58