• Servlet学习之Filter


    1.前言

    如果你做了一个管理系统,那么你的多个Servlet必然要判断用户是否登陆。这就意味着没一个Servlet你都少不了一段判断的代码,这样就会导致我们的代码冗余。所以就有了过滤器(Filter)的出现。有了过滤器我们就可以在所有用户请求之前,过滤掉一部分不符合要求的请求(比如未登录的用户)。

    2.用法

    • 首先我们要使用过滤器的话,那么就要实现一个接口jarkata.servlet.Filter(如果你的Tomcat是10以前的版本那就是javax包)

    • 然后实现接口里的三个方法init、doFilter、destroy

      • init方法:在Filter对象第一次被创建之后调用,并且只调用一次
      • doFilter方法:只要用户发送一次请求,则执行一次。发送N次请求,则执行N次。在这个方法中编写过滤规则
        • 在doFIlter中有一行常见的代码chain.doFilter(request, response),他的作用是执行下一个过滤器,如果没有下一个过滤器,那么就执行相应的Servlet。
      • destroy方法:在Filter对象被释放/销毁之前调用,并且只调用一次
    • 最后我们需要在web.xml中对Filter进行配置。这个配置和Servlet的配置很相似。

      • <filter>
            <filter-name>filter2filter-name>
            <filter-class>com.bjpowernode.javaweb.servlet.Filter2filter-class>
        filter>
        <filter-mapping>
            <filter-name>filter2filter-name>
            <url-pattern>*.dourl-pattern>
        filter-mapping>
        
        • 1
        • 2
        • 3
        • 4
        • 5
        • 6
        • 7
        • 8
      • 注意:一般情况下我们都是直接在web.xml中直接对Filter进行配置,因为这样可以更加灵活。

      • 关于Filter的配置路径

        • /a.do、/b.do、/dept/save。这些配置方式都是精确匹配。
        • /* 匹配所有路径。
        • *.do 后缀匹配。不要以 / 开始
        • /dept/* 前缀匹配。

    3.Filter与Servlet

    • 创建:一般情况下,服务器启动会默认创建Filter对象,而不会默认创建Servlet对象。两者都是单实例。

    • 生命周期:两者的生命周期相同,不过Filter会在服务器启动阶段就自动实例化。

    • 优先级:如果一个路径对应一个Servlet也对应一个Filter,对这个路径发出请求,那么一定是请求Filter。

    4.Filter的优先级

    • 如果是在web.xml文件中配置,那么就是从上到下优先级逐级降低。一般情况下都在web.xml文件中配置Filter。
    • 如果是使用注释@WebFilter(),那么就会根据过滤器类名确定过滤器的优先级。
      • 比如FilterA的优先级大于FilterB,Filter1的优先级大于FIlter2。

    5.责任链设计模式

    • 过滤器最大的优点:
      • 在程序编译阶段不会确定调用顺序。因为Filter的调用顺序是配置到web.xml文件中的,只要修改web.xml配置文件中filter-mapping的顺序就可以调整Filter的执行顺序。显然Filter的执行顺序是在程序运行阶段动态组合的。那么这种设计模式被称为责任链设计模式。
    • 责任链设计模式最大的核心思想:
      • 在程序运行阶段,动态的组合程序的调用顺序。
  • 相关阅读:
    HNU-CSer的推免经历记录
    汇编分析Swift中的String
    P21升级后,用旧的spec模板生成的defime.xml中WhereClauses(VLM)里的逗号不能正常显示
    CPU受限直接执行
    QML20、布局
    win10应用商店怎么重新安装?
    基于线性回归根据饮食习惯和身体状况估计肥胖水平
    orderby是如何工作的?
    剑指Offer10- I. 斐波那契数列
    7.1、如何理解Flink中的时间语义
  • 原文地址:https://blog.csdn.net/qq_52002412/article/details/126051873