如何使用Filter(过滤器二)

目录

一、过滤器链

二、执行顺序

三、示例说明


一、过滤器链

本片文章接如何使用Filter(过滤器一)-CSDN博客https://blog.csdn.net/u011529483/article/details/142059978?spm=1001.2014.3001.5502

继续说说过滤器的执行顺序。

过滤器和拦截器一样都是可以配置多个的,以链式的形式一个一个的执行,所以就会有它的执行顺序。

页面请求----过滤器1、过滤器2......----拦截器1、拦截器2......----控制器(Controller)

二、执行顺序

过滤器的执行顺序和配置顺序有关,如下代码的执行顺序是BwFilter先执行,然后AwFilter。因为BwFilter配置在前面。

复制代码
<filter-mapping>
  <filter-name>BwFilter</filter-name>
  <url-pattern>/*</url-pattern>
</filter-mapping>
<filter-mapping>
  <filter-name>AwFilter</filter-name>
  <url-pattern>/*</url-pattern>
</filter-mapping>

三、示例说明

1. 接上篇 如何使用Filter(过滤器一)-CSDN博客https://blog.csdn.net/u011529483/article/details/142059978?spm=1001.2014.3001.5502文章中的项目基础上增加一个过滤器BwFilter.java类:

java 复制代码
package com.wqbr.showebsite.wfilter;

import javax.servlet.*;
import java.io.IOException;

/**
 * @author lv
 * @date 2024年9月9日
 *
 */
public class BwFilter implements Filter {

    @Override
    public void init(FilterConfig config) throws ServletException {
        System.out.println("BwFilter .... init执行。。。。。。");
    }

    @Override
    public void destroy() {
        System.out.println("BwFilter .... destroy销毁。。。。。。");
    }

    @Override
    public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws ServletException, IOException {
        System.out.println("BwFilter .... doFilter执行。。。。。。");
        chain.doFilter(request, response);
    }
}

2. 在web.xml中配置过滤器BwFilter:

XML 复制代码
  <!--配置自定义过滤器-->
  <filter>
    <filter-name>AwFilter</filter-name>
    <filter-class>com.wqbr.showebsite.wfilter.AwFilter</filter-class>
  </filter>
  <filter>
    <filter-name>BwFilter</filter-name>
    <filter-class>com.wqbr.showebsite.wfilter.BwFilter</filter-class>
  </filter>
  <filter-mapping>
    <filter-name>BwFilter</filter-name>
    <url-pattern>/*</url-pattern>
  </filter-mapping>
  <filter-mapping>
    <filter-name>AwFilter</filter-name>
    <url-pattern>/*</url-pattern>
  </filter-mapping>

3. 启动项目

控制台运行结果如下:BwFilter的doFilter方法先执行,再执行AwFilter的doFilter方法。而<filter-mapping>配置时同样先配置的BwFilter,所以这个BwFilter先执行了doFilter方法。


补充: 由于本示例项目是springmvc项目,且自定义了一个HandlerInterceptorAdapter拦截器。

所以也测试下过滤器Filter和Spring MVC拦截器的执行顺序。我们通过页面请求Controller后,控制台打印如下:

可以看出执行顺序是:Filter先执行、再执行拦截器的preHandle方法、然后执行的Controller方法。关于Spring MVC拦截器的使用可以查看如何使用HandlerInterceptorAdapter拦截器-CSDN博客https://blog.csdn.net/u011529483/article/details/141925173?spm=1001.2014.3001.5502

完!

相关推荐
我是华为OD~HR~栗栗呀1 小时前
华为OD-23届-测试面经
java·前端·c++·python·华为od·华为·面试
yy7634966681 小时前
WPF 之 简单高效的Revit多语言支持方案
java·大数据·linux·服务器·wpf
我是华为OD~HR~栗栗呀1 小时前
华为od面经-23届-Java面经
java·c语言·c++·python·华为od·华为·面试
程序员爱钓鱼4 小时前
Python编程实战 · 基础入门篇 | 元组(tuple)
后端·python·ipython
程序员爱钓鱼4 小时前
Python编程实战 · 基础入门篇 | 列表(list)
后端·python·ipython
青云交5 小时前
Java 大视界 -- 基于 Java 的大数据机器学习模型在图像识别中的迁移学习与模型优化
java·大数据·迁移学习·图像识别·模型优化·deeplearning4j·机器学习模型
2501_909800816 小时前
Java 集合框架之 Set 接口
java·set接口
断剑zou天涯6 小时前
【算法笔记】暴力递归尝试
java·笔记·算法
Nobody_Cares7 小时前
JWT令牌
java
沐浴露z7 小时前
Kafka入门:基础架构讲解,安装与使用
java·分布式·kafka