我用两个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本身,只有码头的问题。
Jetty不使用log4j。
为什么您希望Web容器在servlet规范之外提供您的WebApp日志记录?
查看实际servlet规范日志记录的各种ServletContext. log()
方法
建议:将log4jjar文件放在webapp的WEB-INF/lib/
中