24 votos

ClassNotFoundException al iniciar tomcat

Estoy tratando de hacer un Webservice REST. Después de algunas horas para encontrar cómo puedo solucionar el problema...

Mi proyecto se ve como :

enter image description here

La traza es :

8 déc. 2011 18:31:36 org.apache.catalina.core.AprLifecycleListener init
INFO: The Apache Tomcat Native library which allows optimal performance in production     environments was not found on the java.library.path: C:\Program Files\MyEclipse\Common\binary\com.sun.java.jdk.win32.x86_1.6.0.013\bin;C:\Program Files\MyEclipse\Common\plugins\com.genuitec.eclipse.easie.tomcat.myeclipse_9.0.0.me201109141806\tomcat\bin
8 déc. 2011 18:31:36 org.apache.coyote.http11.Http11Protocol init
INFO: Initialisation de Coyote HTTP/1.1 sur http-8080
8 déc. 2011 18:31:36 org.apache.catalina.startup.Catalina load
INFO: Initialization processed in 394 ms
8 déc. 2011 18:31:37 org.apache.catalina.core.StandardService start
INFO: Démarrage du service Catalina
8 déc. 2011 18:31:37 org.apache.catalina.core.StandardEngine start
INFO: Starting Servlet Engine: Apache Tomcat/6.0.13
8 déc. 2011 18:31:37 org.apache.catalina.startup.HostConfig deployWAR
INFO: Déploiement de l'archive Test-0.0.1-SNAPSHOT.war de l'application web
8 déc. 2011 18:31:37 org.apache.catalina.loader.WebappClassLoader validateJarFile
INFO: validateJarFile(C:\Documents and Settings\Naya\Workspaces\MyEclipse 10\.metadata\.me_tcat\webapps\Test-0.0.1-SNAPSHOT\WEB-INF\lib\javax.servlet-3.0.1.jar) - jar not loaded. See Servlet Spec 2.3, section 9.7.2. Offending class: javax/servlet/Servlet.class
8 déc. 2011 18:31:37 org.apache.catalina.loader.WebappClassLoader validateJarFile
INFO: validateJarFile(C:\Documents and Settings\Naya\Workspaces\MyEclipse 10\.metadata\.me_tcat\webapps\Test-0.0.1-SNAPSHOT\WEB-INF\lib\servlet-api-2.5.jar) - jar not loaded. See Servlet Spec 2.3, section 9.7.2. Offending class: javax/servlet/Servlet.class
8 déc. 2011 18:31:38 org.apache.catalina.core.ApplicationContext log
INFO: La servlet Test JAX-RS REST Servlet est marqué comme indisponible
8 déc. 2011 18:31:38 org.apache.catalina.core.ApplicationContext log
GRAVE: Error loading WebappClassLoader
delegate: false
  repositories:
    /WEB-INF/classes/
----------> Parent Classloader:
org.apache.catalina.loader.StandardClassLoader@19e8329
 com.sun.jersey.spi.container.servlet.ServletContainer
java.lang.ClassNotFoundException: com.sun.jersey.spi.container.servlet.ServletContainer
    at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1358)
    at org.apache.catalina.loader.WebappClassLoader.loadClass(WebappClassLoader.java:1204)
    at org.apache.catalina.core.StandardWrapper.loadServlet(StandardWrapper.java:1083)
    at org.apache.catalina.core.StandardWrapper.load(StandardWrapper.java:981)
    at org.apache.catalina.core.StandardContext.loadOnStartup(StandardContext.java:4042)
    at org.apache.catalina.core.StandardContext.start(StandardContext.java:4348)
    at org.apache.catalina.core.ContainerBase.addChildInternal(ContainerBase.java:791)
    at org.apache.catalina.core.ContainerBase.addChild(ContainerBase.java:771)
    at org.apache.catalina.core.StandardHost.addChild(StandardHost.java:525)
    at org.apache.catalina.startup.HostConfig.deployWAR(HostConfig.java:825)
    at org.apache.catalina.startup.HostConfig.deployWARs(HostConfig.java:714)
    at org.apache.catalina.startup.HostConfig.deployApps(HostConfig.java:490)
    at org.apache.catalina.startup.HostConfig.start(HostConfig.java:1138)
    at org.apache.catalina.startup.HostConfig.lifecycleEvent(HostConfig.java:311)
    at org.apache.catalina.util.LifecycleSupport.fireLifecycleEvent(LifecycleSupport.java:117)
    at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1053)
    at org.apache.catalina.core.StandardHost.start(StandardHost.java:719)
    at org.apache.catalina.core.ContainerBase.start(ContainerBase.java:1045)
    at org.apache.catalina.core.StandardEngine.start(StandardEngine.java:443)
    at org.apache.catalina.core.StandardService.start(StandardService.java:516)
    at org.apache.catalina.core.StandardServer.start(StandardServer.java:710)
    at org.apache.catalina.startup.Catalina.start(Catalina.java:566)
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
    at java.lang.reflect.Method.invoke(Method.java:597)
    at org.apache.catalina.startup.Bootstrap.start(Bootstrap.java:288)
    at org.apache.catalina.startup.Bootstrap.main(Bootstrap.java:413)

Mi lunes web.xml :

<?xml version="1.0" encoding="UTF-8"?>
<web-app version="3.0" 
    xmlns="http://java.sun.com/xml/ns/javaee" 
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" 
    xsi:schemaLocation="http://java.sun.com/xml/ns/javaee 
    http://java.sun.com/xml/ns/javaee/web-app_3_0.xsd">
  <display-name></display-name> 
  <servlet>
    <display-name>Test JAX-RS REST Servlet</display-name>
    <servlet-name>Test JAX-RS REST Servlet</servlet-name>
    <servlet-class>
        com.sun.jersey.spi.container.servlet.ServletContainer
    </servlet-class>
  </servlet>
  <servlet-mapping>
    <servlet-name>Test JAX-RS REST Servlet</servlet-name>
    <url-pattern>/services/*</url-pattern>
  </servlet-mapping>
  <welcome-file-list>
    <welcome-file>index.jsp</welcome-file>
  </welcome-file-list>
</web-app>

Alguien me puede ayudar ? Algunas informaciones se están perdiendo ?

Thx de antemano, Sebastien

35voto

Diego Puntos 571

Solución:

Sólo agregar la dependencia en pom.xml:

 <dependency>
      <groupId>com.sun.jersey</groupId>
      <artifactId>jersey-servlet</artifactId>
      <version>1.13</version>
 </dependency>



Ahora, su aplicación tendrá la clase com.sol.jersey.spi.contenedor.servlet.ServletContainer

ps: Recuerde comprobar si las bibliotecas están siendo enviados a los tomcat implementar.

Para comprobar:

Haz clic derecho sobre el proyecto -> Propiedades -> Implementación de Ensamblador y asegúrese de que la Fuente de la ficha contiene Maven Dependecies.

De otra manera:

Haga clic en el botón Agregar -> Java Build Path -> Maven Dependecies -> Finalizar.

Listo cada vez que ejecuta la aplicación de todas las libs será importado en el de implementar.

ps: Donde el proyecto de Maven se actualiza, se debe rehacer estos pasos.

32voto

Anjaneya Reddy Puntos 276

Me he encontrado con el mismo problema. Yo estaba usando la Versión 1.12.

No he podido encontrar el de la clase com.sun.jersey.spi.container.servlet.ServletContainer en el "jersey-server-1.12.jar" o "jersey-core-1.12.jar" como se sugiere en algunos otros foros.

Usted puede fácilmente verificar esta en Eclipse, cuando se agregan a la construcción de Camino y el aviso de que no tiene esa clase en los mencionados archivos jar.

Busqué por los alrededores y encontró lo siguiente:

Parece que la clase com.sun.jersey.spi.container.servlet.ServletContainer se encuentra en otro archivo jar ("jersey-servlet-1.12.jar").

No se encontró ninguna documentación acerca de esto. Sin embargo tener este archivo en mi WEB-INF/lib resuelto este problema.

Espero que esto ayude.

18voto

luigi7up Puntos 973

Si estás trabajando con Maven , a continuación, el posible problema podría ser que los frascos no se despliegan a su Tomcat. Así, tienes a tu Dependencias Maven en Java Build Path (Proyecto > Propiedades > Build path), pero cuando se ejecuta el proyecto en su Tomcat desde Eclipse Maven Dependencias no se despliegan a TOmcat. Para solucionar esto es necesario: clic derecho > propiedades y seleccione "Despliegue de la Asamblea". Y añadir Java Build Path Entradas. De esta manera usted está diciendo a la PLANTA de plugin (el Tomcat en Eclipse) que también debe copiar la de la Experta en frascos enter image description here

9voto

JasonPlutext Puntos 6417

En Jersey 2.0, el contenedor de servlets aplicación cambiado. Usted necesidad de utilizar org.glassfish.jersey.servlet.ServletContainer en lugar de la antigua com.sol.jersey.spi.contenedor.servlet.ServletContainer

La clase es en

    <dependency>
        <groupId>org.glassfish.jersey.containers</groupId>
        <artifactId>jersey-container-servlet-core</artifactId>
        <version>2.0-m11</version>
    </dependency>

Usted puede crear un esqueleto proyecto a través de:

mvn archetype:generate -DarchetypeArtifactId=jersey-quickstart-webapp -DarchetypeGroupId=org.glassfish.jersey.archetypes -
DinteractiveMode=false -DgroupId=com.example -DartifactId=simple-service -Dpackage=com.example -DarchetypeVersion=2.0-m11

3voto

Anupam Puntos 31

Usted necesita poner el Jersey FRASCO en su WEB-INF/lib del directorio, si se ejecuta el Tomcat por separado o en ejecución con Eclipse.

Esto funcionó para mí.

Iteramos.com

Iteramos es una comunidad de desarrolladores que busca expandir el conocimiento de la programación mas allá del inglés.
Tenemos una gran cantidad de contenido, y también puedes hacer tus propias preguntas o resolver las de los demás.

Powered by: