2013-07-24 11 views
21

Pierwszy raz próbuję WebService za pomocą jerseyu. Poniższy kod dostałem z jakiegoś bloga. otrzymuję następujący błąd 500, gdy próbuję usługi sieci Web przy użyciu Java jersey klientajersey NoClassDefFoundError: org/objectweb/asm/wyjątek ClassVisitor

javax.servlet.ServletException: Servlet.init() for servlet Jersey Root REST Service threw exception 
    org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:472) 
    org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:99) 
    org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:953) 
    org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:408) 
    org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1008) 
    org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:589) 
    org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:310) 
    java.util.concurrent.ThreadPoolExecutor$Worker.runTask(Unknown Source) 
    java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source) 
    java.lang.Thread.run(Unknown Source) 

root cause 

java.lang.NoClassDefFoundError: org/objectweb/asm/ClassVisitor 
    com.sun.jersey.api.core.ScanningResourceConfig.init(ScanningResourceConfig.java:79) 
    com.sun.jersey.api.core.servlet.WebAppResourceConfig.init(WebAppResourceConfig.java:102) 
    com.sun.jersey.api.core.servlet.WebAppResourceConfig.<init>(WebAppResourceConfig.java:89) 
    com.sun.jersey.api.core.servlet.WebAppResourceConfig.<init>(WebAppResourceConfig.java:74) 
    com.sun.jersey.spi.container.servlet.WebComponent.getWebAppResourceConfig(WebComponent.java:672) 
    com.sun.jersey.spi.container.servlet.ServletContainer.getDefaultResourceConfig(ServletContainer.java:415) 
    com.sun.jersey.spi.container.servlet.ServletContainer.getDefaultResourceConfig(ServletContainer.java:582) 
    com.sun.jersey.spi.container.servlet.WebServletConfig.getDefaultResourceConfig(WebServletConfig.java:87) 
    com.sun.jersey.spi.container.servlet.WebComponent.createResourceConfig(WebComponent.java:703) 
    com.sun.jersey.spi.container.servlet.WebComponent.createResourceConfig(WebComponent.java:678) 
    com.sun.jersey.spi.container.servlet.WebComponent.init(WebComponent.java:203) 
    com.sun.jersey.spi.container.servlet.ServletContainer.init(ServletContainer.java:374) 
    com.sun.jersey.spi.container.servlet.ServletContainer.init(ServletContainer.java:557) 
    javax.servlet.GenericServlet.init(GenericServlet.java:160) 
    org.apache.catalina.authenticator.AuthenticatorBase.invoke(AuthenticatorBase.java:472) 
    org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:99) 
    org.apache.catalina.valves.AccessLogValve.invoke(AccessLogValve.java:953) 
    org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:408) 
    org.apache.coyote.http11.AbstractHttp11Processor.process(AbstractHttp11Processor.java:1008) 
    org.apache.coyote.AbstractProtocol$AbstractConnectionHandler.process(AbstractProtocol.java:589) 
    org.apache.tomcat.util.net.JIoEndpoint$SocketProcessor.run(JIoEndpoint.java:310) 
    java.util.concurrent.ThreadPoolExecutor$Worker.runTask(Unknown Source) 
    java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source) 
    java.lang.Thread.run(Unknown Source)' 

Poniżej jest mój plik 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_3_0.xsd" id="WebApp_ID" version="3.0"> 
    <display-name>RestFulWeb</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> 
    <servlet-name>Jersey Root REST Service</servlet-name> 
    <servlet-class>com.sun.jersey.spi.container.servlet.ServletContainer</servlet-class> 

<init-param> 
    <param-name>com.sun.jersey.api.json.POJOMappingFeature</param-name> 
    <param-value>true</param-value> 
</init-param> 
<load-on-startup>1</load-on-startup> 
    </servlet> 
    <servlet-mapping> 
    <servlet-name>Jersey Root REST Service</servlet-name> 
    <url-pattern>/*</url-pattern> 
    </servlet-mapping> 

</web-app>' 

Tutaj Próbowałem, dodając również, że pakiet nie help:

Dodano tylko jeden plik jar jersey-bundle-1.14.jar. Poniżej mój serwer Jersey

package com.rest.server; 

import javax.ws.rs.DELETE; 
import javax.ws.rs.GET; 
import javax.ws.rs.POST; 
import javax.ws.rs.PUT; 
import javax.ws.rs.Path; 
import javax.ws.rs.PathParam; 
import javax.ws.rs.Produces; 
import javax.ws.rs.core.MediaType; 

import com.rest.data.Hello; 

// POJO, no interface no extends 

// The class registers its methods for the HTTP GET request using the @GET annotation. 
// Using the @Produces annotation, it defines that it can deliver several MIME types, 
// text, XML and HTML. 

// The browser requests per default the HTML MIME type. 

//Sets the path to base URL + /hello 
@Path("/hello") 
public class HelloWorldRest { 

@GET 
@Path("/{param}/") 
public String getMsg(@PathParam("param") String msg) { 

    String output = "Jersey say : " + msg; 

    return output; 

} 
@GET 
@Path("/world") 
public String getFixedMsg(String msg) { 

    String output = "Jersey say : fixed path" + msg; 

    return output; 

} 
// This method is called if TEXT_PLAIN is request 
@GET 
//@Path("helloworld") 
@Produces(MediaType.TEXT_PLAIN) 
public String sayPlainTextHello() { 
    System.out.println("sayPlain"); 
    return "Hello Jersey"; 
} 

// This method is called if XML is request 
@GET 
//@Path("helloworld") 
@Produces(MediaType.TEXT_XML) 
public String sayXMLHello() { 
    System.out.println("sayXML"); 
    return "" + " Hello Jersey" + ""; 
} 

// This method is called if HTML is request 
@GET 
//@Path("helloworld") 
@Produces(MediaType.TEXT_HTML) 
public String sayHtmlHello() { 
    System.out.println("sayHTML"); 
    return "<html> " + "<title>" + "Hello Jersey" + "</title>" 
    + "<body><h1>" + "Hello Jersey" + "</body></h1>" + "</html> "; 
} 

// This method is called if JSON is request 
@GET 
//@Path("helloworld") 
@Produces(MediaType.APPLICATION_JSON) 
public Hello sayJsonHello() { 
    return new Hello("Hello", "Jersey"); 
} 

@POST 
@Produces(MediaType.APPLICATION_JSON) 
public Hello createHello(Hello hello) 
{ 
    System.out.println("post"); 
    return hello; 
} 

}' 

obecnie próbuję tylko z GET uderzenie następujący adres URL http://localhost:8080/RestFulWeb/hello, otrzymuję błąd 505.

DO ominąłeś jakiekolwiek pliki JAR, ale nie otrzymałem żadnego błędu czasu kompilacji.

+0

Czy dodałeś wymagany słoik do swojego projektu? – BBdev

+1

@BBdev: dziękuję, sprawdziłem, ominąłem słoik, poprzednio dodano tylko jeden plik jar jersey-bundle-1.14.jar. teraz asm.jar i json.jar, teraz działa dobrze. – user2502314

+0

@ BBDev, jedna wątpliwość jako nowa tutaj tutaj .. jeśli przegapiłem jakiś słoik powinien dać kompilacji rytuał błędu? – user2502314

Odpowiedz

34

Jest to spowodowane przez brakujących asm.jar,

Dodaj tę zależność

<dependency> 

    <groupId>asm</groupId> 

    <artifactId>asm</artifactId> 

    <version>3.3.1</version> 

</dependency> 
+0

Działa to dobrze z com.sun.jersey: jersey-bundle: 1.17 – tomtomssi

0

Pisząc usługa byłem coraz następujący błąd:

INFO: Scanning for root resource and provider classes in the packages: 
    com.webservice.services 
Exception in thread "main" java.lang.NoClassDefFoundError: org/objectweb/asm/ClassVisitor 
    at com.sun.jersey.api.core.ScanningResourceConfig.init(ScanningResourceConfig.java:79) 
    at com.sun.jersey.api.core.PackagesResourceConfig.init(PackagesResourceConfig.java:104) 
    at com.sun.jersey.api.core.PackagesResourceConfig.<init>(PackagesResourceConfig.java:78) 
    at com.webservice.StartWebService.startAttrService(StartWebService.java:32) 
    at com.webservice.StartWebService.main(StartWebService.java:20) 
Caused by: java.lang.ClassNotFoundException: org.objectweb.asm.ClassVisitor 
    at java.net.URLClassLoader$1.run(URLClassLoader.java:366) 
    at java.net.URLClassLoader$1.run(URLClassLoader.java:355) 
    at java.security.AccessController.doPrivileged(Native Method) 
    at java.net.URLClassLoader.findClass(URLClassLoader.java:354) 
    at java.lang.ClassLoader.loadClass(ClassLoader.java:425) 
    at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:308) 
    at java.lang.ClassLoader.loadClass(ClassLoader.java:358) 
    ... 5 more 

włączyłem asm .jar w moim projekcie java i błąd zniknął. Podążałem za krokami od restful-web-services-first-application-mock-service-using-pure-java