2011-07-19 22 views
0

部署Maven的web项目,当我尝试运行我的码头项目,我得到这个异常:在码头

抛出java.lang.ClassNotFoundException:默认

完整的堆栈:

Launching Jetty with port 8080, context/and webapp path src/main/webapp 
2011-07-19 16:49:56.832:INFO::Logging to STDERR via org.mortbay.log.StdErrLog 
2011-07-19 16:49:56.841:INFO::jetty-6.1.26 
2011-07-19 16:49:57.181:WARN::EXCEPTION 
java.lang.ClassNotFoundException: Default 
    at java.net.URLClassLoader$1.run(Unknown Source) 
    at java.security.AccessController.doPrivileged(Native Method) 
    at java.net.URLClassLoader.findClass(Unknown Source) 
    at java.lang.ClassLoader.loadClass(Unknown Source) 
    at sun.misc.Launcher$AppClassLoader.loadClass(Unknown Source) 
    at java.lang.ClassLoader.loadClass(Unknown Source) 
    at org.mortbay.jetty.webapp.WebAppClassLoader.loadClass(WebAppClassLoader.java:401) 
    at org.mortbay.jetty.webapp.WebAppClassLoader.loadClass(WebAppClassLoader.java:363) 
    at org.mortbay.util.Loader.loadClass(Loader.java:91) 
    at org.mortbay.util.Loader.loadClass(Loader.java:71) 
    at org.mortbay.jetty.servlet.Holder.doStart(Holder.java:73) 
    at org.mortbay.jetty.servlet.ServletHolder.doStart(ServletHolder.java:242) 
    at org.mortbay.component.AbstractLifeCycle.start(AbstractLifeCycle.java:50) 
    at org.mortbay.jetty.servlet.ServletHandler.initialize(ServletHandler.java:736) 
    at org.mortbay.jetty.servlet.Context.startContext(Context.java:140) 
    at org.mortbay.jetty.webapp.WebAppContext.startContext(WebAppContext.java:1282) 
    at org.mortbay.jetty.handler.ContextHandler.doStart(ContextHandler.java:518) 
    at org.mortbay.jetty.webapp.WebAppContext.doStart(WebAppContext.java:499) 
    at org.mortbay.component.AbstractLifeCycle.start(AbstractLifeCycle.java:50) 
    at org.mortbay.jetty.handler.HandlerWrapper.doStart(HandlerWrapper.java:130) 
    at org.mortbay.jetty.Server.doStart(Server.java:224) 
    at org.mortbay.component.AbstractLifeCycle.start(AbstractLifeCycle.java:50) 
    at net.sourceforge.eclipsejetty.launch.JettyLauncherMain.launch(JettyLauncherMain.java:67) 
at  net.sourceforge.eclipsejetty.launch.JettyLauncherMain.main(JettyLauncherMain.java:50) 
2011-07-19 16:49:57.184:INFO:/:Unavailable javax.servlet.UnavailableException: Default 
2011-07-19 16:49:57.185:WARN::failed Default: java.lang.NullPointerException 
2011-07-19 16:49:57.283:WARN::Failed startup of context  [email protected]{/,src/main/webapp} 
java.lang.NullPointerException 
    at java.lang.Class.isAssignableFrom(Native Method) 
    at org.mortbay.jetty.servlet.ServletHolder.doStart(ServletHolder.java:256) 
    at org.mortbay.component.AbstractLifeCycle.start(AbstractLifeCycle.java:50) 
    at org.mortbay.jetty.servlet.ServletHandler.initialize(ServletHandler.java:736) 
    at org.mortbay.jetty.servlet.Context.startContext(Context.java:140) 
    at org.mortbay.jetty.webapp.WebAppContext.startContext(WebAppContext.java:1282) 
    at org.mortbay.jetty.handler.ContextHandler.doStart(ContextHandler.java:518) 
    at org.mortbay.jetty.webapp.WebAppContext.doStart(WebAppContext.java:499) 
    at org.mortbay.component.AbstractLifeCycle.start(AbstractLifeCycle.java:50) 
    at org.mortbay.jetty.handler.HandlerWrapper.doStart(HandlerWrapper.java:130) 
    at org.mortbay.jetty.Server.doStart(Server.java:224) 
    at org.mortbay.component.AbstractLifeCycle.start(AbstractLifeCycle.java:50) 
    at  net.sourceforge.eclipsejetty.launch.JettyLauncherMain.launch(JettyLauncherMain.java:67) 
at net.sourceforge.eclipsejetty.launch.JettyLauncherMain.main(JettyLauncherMain.java:50) 
2011-07-19 16:49:57.294:INFO::Started [email protected]:8080 

我说它无法加载我的类Default.java(我的项目中唯一的类)。

这里是我的结构(修订版)

enter image description here

我使用码头插件部署我的项目。 要运行它,我右键单击我的项目,选择调试AS->调试配置...我选择一个低于设置:

enter image description here

这里也是我的web.xml文件:

<?xml version="1.0" encoding="UTF-8"?> 
<web-app xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://java.sun.com/xml/ns/javaee" xmlns:web="http://java.sun.com/xml/ns/javaee/web- app_2_5.xsd" xsi:schemaLocation="http://java.sun.com/xml/ns/javaee http://java.sun.com/xml/ns/javaee/web-app_2_5.xsd" id="WebApp_ID" version="2.5"> 
    <display-name>ServletWeb-Test</display-name> 
    <welcome-file-list> 
    <welcome-file>index.html</welcome-file> 
    <welcome-file>index.htm</welcome-file> 
    <welcome-file>index.jsp</welcome-file> 
    <welcome-file>default.html</welcome-file> 
    <welcome-file>default.htm</welcome-file> 
    <welcome-file>default.jsp</welcome-file> 
    </welcome-file-list> 
    <servlet> 
    <description></description> 
    <display-name>Default</display-name> 
    <servlet-name>Default</servlet-name> 
    <servlet-class>Default</servlet-class> 
    </servlet> 
<servlet-mapping> 
    <servlet-name>Default</servlet-name> 
    <url-pattern>/Default</url-pattern> 
</servlet-mapping> 

我跑出来的想法,我找不到为什么我得到这个错误。 我有人可以帮助我,我很乐意欣赏它!

回答

5

你想把你的Java类文件放在src/main/java中,而不是src/main/resources。资源中的文件不会被编译,因为它们不应该是源代码。通常你会把XML描述符文件,图像文件等放在资源中。

eclipse/maven构建项目时,src/main/resources的内容将被复制到目标文件夹中。

+3

另外,你不应该把类放在默认包中。一些容器和其他技术不能很好地处理默认包。我不确定Jetty是否是其中之一。 –

+0

@ Jon7哼,这很奇怪。当我这样做时,我右键单击src/main并添加了一个java类。看起来它被自动放入/资源...为什么? Ryan:注意。我将把我的课程移到一个命名包中。谢谢。 – Mathieu

+0

@Tigel我不太确定...也许m2eclipse正在表演......这个插件总是一个很好的替罪羊:) – Jon7