• Filter


    1. Filter是什么

    ①. JavaWeb的一个重要组件,可以对发送到Servlet的请求进行拦截,并对响应也进行拦截;

    ②.Filter是实现了javax.servlet.Filter接口的Java类;

    ③.Filter需要在web.xml文件中进行配置和映射。

    2. 如何创建、配置一个Filter

    ①. 创建一个Filter类:即实现javax.servlet.Filter接口;

    ②. 在web.xml文件中配置并映射该Filter,其中url-pattern指定该Filter可以拦截哪些资源(即通过哪些url访问到该Filter)

    <!-- 注册Filter -->
    <filter>
      <filter-name>passwordFilter</filter-name>
      <filter-class>com.ldj.test.java.web.filtertest.PasswordFilter</filter-class>
    </filter>
    <! 映射Filter -->
    <filter-mapping>
      <filter-name>passwordFilter</filter-name>
      <url-pattern>/hello.jsp</url-pattern>
    </filter-mapping>

    <url-pattern>有三种匹配方式和Servlet的配置方式类似

    • 绝对路径匹配:以/开头 不包含通配符 * 是一个绝对访问路径。例如:/demo、/index.jsp。
    • 目录匹配:以/ 开头,以 * 结尾。例如:/*、/servlet/*、/servlet/xxx/*。
    • 扩展名匹配:不能以/ 开头,也不能以*结尾 只能以后缀名结尾 例如:*.do、*.demo等。

    3. Filter的API

    (1)Filter 接口: 

    ① public void init(FilterConfig filterConfig):类似于 Servlet 的 init 方法。在创建 Filter 对象(Filter 对象在 Servlet 容器加载当前 WEB 应用时即被创建)后,立即被调用,且只被调用一次。该方法用于对当前的 Filter 进行初始化操作。Filter 实例是单例的。FilterConfig 类似于 ServletConfig。可以在 web.xml 文件中配置当前 Filter 的初始化参数。 配置方式也和 Servlet 类似。

    <filter>
      <filter-name>helloFilter</filter-name>
       <filter-class>com.atguigu.javaweb.HelloFilter</filter-class>
      <init-param>
        <param-name>name</param-name>
        <param-value>root</param-value>
      </init-param>
    </filter>

    ② public void doFilter(ServletRequest request, ServletResponse response,FilterChain chain): 真正 Filter 的逻辑代码需要编写在该方法中。每次拦截都会调用该方法。FilterChain: Filter 链。多个 Filter 可以构成一个 Filter 链。

    doFilter(ServletRequest request, ServletResponse response):把请求传给 Filter 链的下一个 Filter,若当前Filter 是 Filter 链的最后一个 Filter,将把请求给到目标 Serlvet(或 JSP)。多个 Filter 拦截的顺序和 <filter-mapping> 配置的顺序有关,靠前的先被调用。

    ③ public void destroy():释放当前 Filter 所占用的资源的方法,类似于servlet的destroy方法。在 Filter 被销毁之前被调用,且只被调用一次。

    4. <dispatcher> 元素

    指定过滤器所拦截的资源被 Servlet 容器调用的方式,可以是REQUEST,INCLUDE,FORWARD和ERROR之一,默认REQUEST.可以设置多个<dispatcher> 子元素用来指定 Filter 对资源的多种调用方式进行拦截。

    ①. REQUEST:当用户直接访问页面时,Web容器将会调用过滤器。如果目标资源是通过RequestDispatcher的include()或forward()方法访问时,那么该过滤器就不会被调用。通过 GET 或 POST 请求直接访问。

    ②. FORWARD:如果目标资源是通过RequestDispatcher的forward()方法访问时,那么该过滤器将被调用,除此之外,该过滤器不会被调用。或 <jsp:forward page="/..." /> 或 通过 page 指令的 errorPage 转发页面 <%@ page errorPage="test.jsp" %>。

    ③. INCLUDE:如果目标资源是通过RequestDispatcher的include()方法访问时,那么该过滤器将被调用。除此之外,该过滤器不会被调用。或 <jsp:include file="/..." />。

    ④. ERROR:如果目标资源是通过声明式异常处理机制调用时,那么该过滤器将被调用。除此之外,过滤器不会被调用。在 web.xml 文件中通过 error-page 节点进行声明:

    <error-page>
        <exception-type>java.lang.ArithmeticException</exception-type>
        <location>/test.jsp</location>
    </error-page>
     
    <filter-mapping>
        <filter-name>secondFilter</filter-name>
        <url-pattern>/test.jsp</url-pattern>
        <dispatcher>REQUEST</dispatcher>
        <dispatcher>FORWARD</dispatcher>
        <dispatcher>INCLUDE</dispatcher>
        <dispatcher>ERROR</dispatcher>
    </filter-mapping>

    5.应用

    ①. 禁用缓存的过滤器

    ②. 解决字符编码的过滤器

    ③. 检验用户是否登录的过滤器

     

  • 相关阅读:
    ubuntu下使用sudo 出现unable to resolve host 解决方法
    Ubuntu下使用mysqli-connect连接mysql时报错:ERROR 1698 (28000): Access denied for user 'root'@'localhost'
    Ubuntu下安装LNMP之独立添加php扩展模块
    Ubuntu下安装LNMP之Mysql的安装及卸载
    Ubuntu下安装LNMP之php7的安装并配置Nginx支持php及卸载php
    Ubuntu使用vim编辑器时出现上下左右键变成ABCD
    Ubuntu下安装LNMP之nginx的卸载
    Ubuntu下使用find / -name aaa* 提示“find: 路径必须在表达式之前: XXXX”
    Ubuntu下安装LNMP之nginx的安装
    ubuntu使用su切换root用户提示“认证失败”
  • 原文地址:https://www.cnblogs.com/itfky/p/13728215.html
Copyright © 2020-2023  润新知