提问者:小点点

jetty-maven-plugin NoClassDefFoundError


我用两个maven子模块创建了maven父模块。它是部署到Tomcat目录的war输出中基于Web的应用程序。问题是,为了测试war文件,我必须启动Tomcat并测试应用程序。对于这种情况,我决定在父POM. xml文件中使用jetty maven插件。下面是它的样子:

<modules>
    <module>hellojavaworld</module>
    <module>application</module>
</modules>




  <plugin>
    <groupId>org.apache.maven.plugins</groupId>
    <artifactId>maven-compiler-plugin</artifactId>
    <configuration>
      <source>1.5</source>
      <target>1.5</target>
    </configuration>
  </plugin>


  <plugin>
       <groupId>org.eclipse.jetty</groupId>
       <artifactId>jetty-maven-plugin</artifactId>
       <version>9.2.11.v20150529</version>
      <configuration>
            <scanIntervalSeconds>10</scanIntervalSeconds>
             <webApp>
              <contextPath>/hellojavaworld</contextPath>           
             </webApp>   
         <war>c:\apache-tomcat-7.0.64\webapps\hellojavaworld.war</war>
        </configuration>
  </plugin>

如果我手动启动Tomcat并使用http://localhost:8080/hellojavaworld它可以正常工作。另一方面,当使用时

mvn码头:运行战争

它的工作原理,但卡住了错误:

HTTP ERROR 500
Problem accessing /hellojavaworld/HelloServlet. Reason: 

Server Error

Caused by:
java.lang.NoClassDefFoundError: org/apache/log4j/Level

我知道这个问题很常见,因为缺少罐子。我知道这些罐子放在c:\apache-tomcat-7.0.64\lib\文件夹中。

所以问题是如何告诉码头将此文件夹用作我的war文件的外部jar?

注意:对于它运行的Tomcat本身,只有码头的问题。


共1个答案

匿名用户

Jetty不使用log4j。

为什么您希望Web容器在servlet规范之外提供您的WebApp日志记录?

查看实际servlet规范日志记录的各种ServletContext. log()方法

建议:将log4jjar文件放在webapp的WEB-INF/lib/

相关问题