一个Filter配置多个url-pattern

项目中遇到一个filter需要配置多个url-pattern,经测试,总结发现

1、错误的方式如下:

 <filter-name>clientLoginSecurityFilter</filter-name>
        <filter-class>org.springframework.web.filter.DelegatingFilterProxy</filter-class>
    </filter>
    <filter-mapping>
        <filter-name>clientLoginSecurityFilter</filter-name>
        <url-pattern>/nameSpaceA/*,/nameSpaceB/*</url-pattern>
    </filter-mapping>

 
 2、有作用,但不能实现需要的效果,只能过滤最下面的url-pattern 

 <filter>
        <filter-name>clientLoginSecurityFilter</filter-name>
        <filter-class>org.springframework.web.filter.DelegatingFilterProxy</filter-class>
    </filter>
   <filter-mapping>
      <filter-name>clientLoginSecurityFilter</filter-name>
      <url-pattern>/nameSpaceA/*</url-pattern>
      <url-pattern>/nameSpaceB/*</url-pattern> 
   </filter-mapping>
3、正确的配置方式

    <filter>
        <filter-name>clientLoginSecurityFilter</filter-name>
        <filter-class>org.springframework.web.filter.DelegatingFilterProxy</filter-class>
    </filter>
    <filter-mapping>
        <filter-name>clientLoginSecurityFilter</filter-name>
        <url-pattern>/nameSpaceA/*</url-pattern>
    </filter-mapping>
<pre name="code" class="html">    <filter-mapping>
        <filter-name>clientLoginSecurityFilter</filter-name>
        <url-pattern>/nameSpaceB/*</url-pattern> 
    </filter-mapping>

 
<pre name="code" class="html">   
 

在Java Web应用中,如果你怀疑存在多个Filter并想检查它们的存在,你可以按照以下几个步骤操作: 1. **查看web.xml**:打开web应用程序的`WEB-INF/web.xml`文件,这是定义Servlet和Filter的地方。在这里,你会看到类似这样的结构: ```xml <filter> <filter-name>Filter1</filter-name> <filter-class>com.example.FilterClass1</filter-class> </filter> <!-- 可能还会有其他filter --> <filter-mapping> <filter-name>Filter1</filter-name> <url-pattern>/*</url-pattern> </filter-mapping> ``` 2. **过滤器名称和类名**:注意每个`<filter>`标签下的`<filter-name>`元素以及对应每个`<filter>`的`<filter-class>`元素,它们分别标识了过滤器的名称和类路径。 3. **过滤器映射**:查找`<filter-mapping>`标签,它们定义了哪些URL模式会被特定的过滤器拦截。如果有多个`<filter-mapping>`,意味着该过滤器会在多种场景下应用。 4. **检查过滤器监听器**:有时,你可能会在`<listener>`标签下找到`ServletContextListener`,它可能包含了对过滤器创建或销毁的通知,这也间接反映了存在的过滤器。 5. **服务器日志**:如果你的应用程序启用了日志记录,查看服务器的日志文件,如Tomcat的`catalina.out`或Jetty的`jetty.log`,可能会有创建过滤器的痕迹。 6. **代码审查**:如果怀疑是某个类库或框架自动生成的过滤器,检查源码或者项目的构建脚本(如Maven或Gradle)是否存在自动注册过滤器的行为。 通过以上步骤,你应该能够确定是否有多个Filter,并了解它们的作用范围和关联关系。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值