【问题标题】:Exception starting filter Struts 2异常启动过滤器 Struts 2
【发布时间】:2014-05-28 05:39:57
【问题描述】:

我正在尝试使用注释和 maven 设置我的第一个 struts 2 应用程序。我正在关注这个例子struts2 annotations example

当我尝试在 tomcat server 7 上运行应用程序时,我遇到了这个异常

    Grave: Exception startin filter struts2
java.lang.ClassNotFoundException: org.apache.struts2.dispatcher.ng.filter. StrutsPrepareAndExecuteFilter
    at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1720)
    at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1571)
    at org.apache.catalina.core.DefaultInstanceManager.loadClass(DefaultInstanceManager.java:529)
    at org.apache.catalina.core.DefaultInstanceManager.loadClassMaybePrivileged(DefaultInstanceManager.java:511)
    at org.apache.catalina.core.DefaultInstanceManager.newInstance(DefaultInstanceManager.java:139)
    at org.apache.catalina.core.ApplicationFilterConfig.getFilter(ApplicationFilterConfig.java:258)
    at org.apache.catalina.core.ApplicationFilterConfig.<init>(ApplicationFilterConfig.java:105)
    at org.apache.catalina.core.StandardContext.filterStart(StandardContext.java:4809)
    at org.apache.catalina.core.StandardContext.startInternal(StandardContext.java:5485)
    at org.apache.catalina.util.LifecycleBase.start(LifecycleBase.java:150)
    at org.apache.catalina.core.ContainerBase$StartChild.call(ContainerBase.java:1559)
    at org.apache.catalina.core.ContainerBase$StartChild.call(ContainerBase.java:1549)
    at java.util.concurrent.FutureTask.run(FutureTask.java:262)
    at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1145)
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:615)
    at java.lang.Thread.run(Thread.java:744)

avr. 14, 2014 10:40:05 AM org.apache.catalina.core.StandardContext startInternal
Grave: Error filterStart
avr. 14, 2014 10:40:05 AM org.apache.catalina.core.StandardContext startInternal
Grave: Erreur de démarrage du contexte [/StrutsAnnotationsExample] suite aux erreurs précédentes
avr. 14, 2014 10:40:05 AM org.apache.coyote.AbstractProtocol start
Infos: Starting ProtocolHandler ["http-bio-8080"]
avr. 14, 2014 10:40:05 AM org.apache.coyote.AbstractProtocol start
Infos: Starting ProtocolHandler ["ajp-bio-8009"]
avr. 14, 2014 10:40:05 AM org.apache.catalina.startup.Catalina start
Infos: Server startup in 991 ms

任何人都可以帮助或告诉我缺少什么吗?

【问题讨论】:

  • 异常清楚地说它无法找到 StrutsPrepareAndExecuteFilter。所以请确保相应的 JAR 文件在类路径中
  • @AvinashK.P 因为我正在使用 maven 导入所需的 jar。为什么要手动将它们添加到 lib 文件夹中
  • @juniordevelopper 因为您没有将它们部署到您的应用程序中。
  • @RomanC 我已经在部署程序集中添加了 maven 依赖项(myProject=>properties=>Deployment Assembly=>add=>java 构建路径条目=>maven 依赖项);这就是您将它们与应用程序一起部署的意思吗?

标签: java maven tomcat struts2 web.xml


【解决方案1】:

看起来教程中提供的示例示例缺少所需的 jar 文件。下载所有需要的 jar 并将它们放在 WEB-INF/lib 下。

【讨论】:

    【解决方案2】:

    从教程中获取的代码看起来像是一个错字。在web.xml中使用以下内容

    <filter>
        <filter-name>struts2</filter-name>
        <filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class>
    </filter>
    
    <filter-mapping>
        <filter-name>struts2</filter-name>
        <url-pattern>/*</url-pattern>
    </filter-mapping>
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2013-09-28
      • 2013-04-05
      • 2013-04-29
      • 2012-02-10
      • 2016-02-17
      • 2015-09-03
      • 2014-10-27
      • 1970-01-01
      相关资源
      最近更新 更多