java.lang.IllegalArgumentException:过滤器映射指定未知过滤器名称<filtername

时间:2016-04-22 10:52:52

标签: servlets mapping servlet-filters illegalargumentexception

=“”

我收到以下异常

Caused by: java.lang.IllegalArgumentException: Filter mapping specifies an unknown filter name MyFilter
    at org.apache.catalina.core.StandardContext.validateFilterMap(StandardContext.java:3174)
    at org.apache.catalina.core.StandardContext.addFilterMap(StandardContext.java:3139)
    at org.apache.catalina.deploy.WebXml.configureContext(WebXml.java:1343)
    at org.apache.catalina.startup.ContextConfig.webConfig(ContextConfig.java:1362)
    at org.apache.catalina.startup.ContextConfig.configureStart(ContextConfig.java:889)
    at org.apache.catalina.startup.ContextConfig.lifecycleEvent(ContextConfig.java:386)
    at org.apache.catalina.util.LifecycleSupport.fireLifecycleEvent(LifecycleSupport.java:117)
    at org.apache.catalina.util.LifecycleBase.fireLifecycleEvent(LifecycleBase.java:90)
    at org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:5472)
    at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:147)
    ... 10 more

过滤器存在于jar文件中,该文件是交付战争的一部分。

@WebFilter(filterName="MyFilter",
        urlPatterns = {"/page/*"})
public class myFilter implements Filter {

有人能告诉我我必须做什么才能找到过滤器吗?

它不是问题java.lang.IllegalArgumentException: The servlets named [X] and [Y] are both mapped to the url-pattern [/url] which is not permitted的副本,因为它是一个非常不同的错误消息

1 个答案:

答案 0 :(得分:4)

换句话说,@WebFilter无法识别。如果metadata-complete="true"元素<web-app>中的web.xml属性,则可能会发生这种情况。它基本上意味着容器假定web.xml本身对元数据是完整的,因此它不会在/WEB-INF/lib中发送的JAR中扫描元数据(注释)。

您有几种选择。

  1. 设置metadata-complete="false"
  2. 完全删除metadata-complete。默认值已为false
  3. 通过<filter>明确注册过滤器。
  4. 另一个可能的原因是Tomcat中的一个错误已在7.0.28中修复。另请参阅此相关问题:Using Tomcat, @WebFilter doesn't work with <filter-mapping> inside web.xml