Tomcat:严重:加载WebappClassLoader时出错

时间:2013-05-13 17:51:54

标签: java eclipse tomcat

请不要标记为重复,对于其他解决方案,请不要帮助!

我在浏览器中尝试运行本教程的404: http://www.vogella.com/articles/REST/article.html

我实际上甚至没有看到WebContent / WEB-INF / classes文件夹。 为什么不生成它?

我在这里只看到解决方案,告诉要清理项目,重新启动Eclipse等等......但在我的情况下没有帮助。我正在使用Tomcat 6,动态网络模块2.5版。

May 13, 2013 8:17:01 PM org.apache.catalina.core.AprLifecycleListener init
INFO: The APR based Apache Tomcat Native library which allows optimal performance in production environments was not found on the java.library.path: .:/Library/Java/Extensions:/System/Library/Java/Extensions:/usr/lib/java
May 13, 2013 8:17:01 PM org.apache.tomcat.util.digester.SetPropertiesRule begin
WARNING: [SetPropertiesRule]{Server/Service/Engine/Host/Context} Setting property 'source' to 'org.eclipse.jst.jee.server:de.vogella.jersey.first' did not find a matching property.
May 13, 2013 8:17:02 PM org.apache.coyote.http11.Http11Protocol init
INFO: Initializing Coyote HTTP/1.1 on http-8080
May 13, 2013 8:17:02 PM org.apache.catalina.startup.Catalina load
INFO: Initialization processed in 524 ms
May 13, 2013 8:17:02 PM org.apache.catalina.core.StandardService start
INFO: Starting service Catalina
May 13, 2013 8:17:02 PM org.apache.catalina.core.StandardEngine start
INFO: Starting Servlet Engine: Apache Tomcat/6.0.37
May 13, 2013 8:17:02 PM com.sun.jersey.api.core.PackagesResourceConfig init
INFO: Scanning for root resource and provider classes in the packages:
  de.vogella.jersey.first
May 13, 2013 8:17:02 PM com.sun.jersey.api.core.ScanningResourceConfig logClasses
INFO: Root resource classes found:
  class de.vogella.jersey.first.Hello
May 13, 2013 8:17:02 PM com.sun.jersey.api.core.ScanningResourceConfig init
INFO: No provider classes found.
May 13, 2013 8:17:02 PM com.sun.jersey.server.impl.application.WebApplicationImpl _initiate
INFO: Initiating Jersey application, version 'Jersey: 1.17 01/17/2013 03:31 PM'
May 13, 2013 8:17:03 PM org.apache.coyote.http11.Http11Protocol start
INFO: Starting Coyote HTTP/1.1 on http-8080
May 13, 2013 8:17:03 PM org.apache.jk.common.ChannelSocket init
INFO: JK: ajp13 listening on /0.0.0.0:8009
May 13, 2013 8:17:03 PM org.apache.jk.server.JkMain start
INFO: Jk running ID=0 time=0/15  config=null
May 13, 2013 8:17:03 PM org.apache.catalina.startup.Catalina start
INFO: Server startup in 1145 ms

并且仍然没有类文件夹!!!

3 个答案:

答案 0 :(得分:1)

Vogel的例子是使用Jersey 1.5。如果您使用的是Jersey 2.0& Servlet 2.X,需要更改web.xml文件中的一些属性。 web-app属性应该反映您正在使用的Servlet版本。此外,ServletContainer现在位于org.glassfish.jersey.servlet包中。所以servlet-class属性应该如下指定:

<servlet-class>org.glassfish.jersey.servlet.ServletContainer</servlet-class> 

例如,对于Servlet 2.5,web.xml文件应如下所示:

<?xml version="1.0" encoding="UTF-8"?>
<web-app version="2.5" xmlns="http://java.sun.com/xml/ns/javaee"
  xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  
  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">
  <display-name>de.vogella.jersey.first</display-name>
  <servlet>
    <servlet-name>Jersey REST Service</servlet-name>
    <servlet-class>org.glassfish.jersey.servlet.ServletContainer</servlet-class>
    <init-param>
      <param-name>jersey.config.server.provider.packages</param-name>
      <param-value>de.vogella.jersey.first</param-value>
    </init-param>
    <load-on-startup>1</load-on-startup>
  </servlet>
  <servlet-mapping>
    <servlet-name>Jersey REST Service</servlet-name>
    <url-pattern>/rest/hello</url-pattern>
  </servlet-mapping>
</web-app>

此信息可在Jersey 2.0 User Guide,第4章,部署RESTful Web服务中找到。

另外,我发现我需要将url-pattern设置为:

    <url-pattern>/rest/hello</url-pattern>

要让它发挥作用,所以我仍然需要调查此问题。

答案 1 :(得分:1)

我也有同样的问题;但是,我已经被困了一天。这是因为罐子的版本最有可能。我设置了一个罐子,可能是第一次拿到的。在类路径中,它当然是错误的版本,或者使用不同版本的Java编译。我以前见过这个。所以我从头开始关注罐子和版本号码,只安装需要的东西,它就像一个冠军。 ;)

答案 2 :(得分:0)

尝试这些步骤(希望您使用的是Eclipse),看看它是否有助于更接近问题。

  1. 导航::“右键单击(项目名称) - &gt;属性 - &gt;源”选项卡并确保选择“project / WebContent / WEB-INF / classes”作为默认输出文件夹。< / p>

  2. 导航“窗口(菜单) - &gt;显示视图 - &gt;其他 - &gt;常规 - &gt;导航器”然后转到“project / WebContent / WEB-INF /”并检查如果“classes”文件夹没有。

  3. 如果没有,则导航“窗口(菜单) - &gt;显示视图 - &gt;其他 - &gt;常规 - &gt;标记”并查看其是否显示任何构建路径错误。如果是这样,请纠正错误,你应该做得很好。