如何使用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

完!

相关推荐
2202_754421548 分钟前
生成MPSOC以及ZYNQ的启动文件BOOT.BIN的小软件
java·linux·开发语言
蓝染-惣右介11 分钟前
【MyBatisPlus·最新教程】包含多个改造案例,常用注解、条件构造器、代码生成、静态工具、类型处理器、分页插件、自动填充字段
java·数据库·tomcat·mybatis
小林想被监督学习12 分钟前
idea怎么打开两个窗口,运行两个项目
java·ide·intellij-idea
HoneyMoose14 分钟前
IDEA 2024.3 版本更新主要功能介绍
java·ide·intellij-idea
我只会发热15 分钟前
Java SE 与 Java EE:基础与进阶的探索之旅
java·开发语言·java-ee
是老余17 分钟前
本地可运行,jar包运行错误【解决实例】:通过IDEA的maven package打包多模块项目
java·maven·intellij-idea·jar
crazy_wsp17 分钟前
IDEA怎么定位java类所用maven依赖版本及引用位置
java·maven·intellij-idea
.Ayang19 分钟前
tomcat 后台部署 war 包 getshell
java·计算机网络·安全·web安全·网络安全·tomcat·网络攻击模型
一直学习永不止步25 分钟前
LeetCode题练习与总结:最长回文串--409
java·数据结构·算法·leetcode·字符串·贪心·哈希表
hummhumm39 分钟前
第 22 章 - Go语言 测试与基准测试
java·大数据·开发语言·前端·python·golang·log4j