2012-01-10 111 views
1

我正在尝试让REST webservices在我的应用中工作。我在Spring 2.5上使用球衣。通过声明1.9生成Web服务的端点。当我部署在Tomcat中生成WAR文件并访问REST Web服务我得到以下异常:访问Jersey REST webservice时出现异常

javax.servlet.ServletException: Servlet.init() for servlet jersey threw exception 
org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:102) 
org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:291) 
org.apache.coyote.http11.Http11AprProcessor.process(Http11AprProcessor.java:877) 
org.apache.coyote.http11.Http11AprProtocol$Http11ConnectionHandler.process(Http11AprProtocol.java:594) 
org.apache.tomcat.util.net.AprEndpoint$Worker.run(AprEndpoint.java:1675) 
java.lang.Thread.run(Thread.java:662) 

根源:

java.lang.NoSuchMethodError: org.objectweb.asm.ClassReader.accept(Lorg/objectweb/asm/ClassVisitor;I)V 
com.sun.jersey.impl.container.config.AnnotatedClassScanner.analyzeClassFile(AnnotatedClassScanner.java:267) 
com.sun.jersey.impl.container.config.AnnotatedClassScanner.indexJar(AnnotatedClassScanner.java:229) 
com.sun.jersey.impl.container.config.AnnotatedClassScanner.indexJar(AnnotatedClassScanner.java:218) 
com.sun.jersey.impl.container.config.AnnotatedClassScanner.indexDir(AnnotatedClassScanner.java:210) 
com.sun.jersey.impl.container.config.AnnotatedClassScanner.index(AnnotatedClassScanner.java:169) 
com.sun.jersey.impl.container.config.AnnotatedClassScanner.scan(AnnotatedClassScanner.java:105) 
com.sun.jersey.api.core.ClasspathResourceConfig.init(ClasspathResourceConfig.java:131) 
com.sun.jersey.api.core.ClasspathResourceConfig.<init>(ClasspathResourceConfig.java:103) 
com.sun.jersey.api.core.ClasspathResourceConfig.<init>(ClasspathResourceConfig.java:85) 
com.sun.jersey.spi.container.servlet.ServletContainer.createResourceConfig(ServletContainer.java:395) 
com.sun.jersey.spi.container.servlet.ServletContainer.init(ServletContainer.java:194) 
org.apache.catalina.valves.ErrorReportValve.invoke(ErrorReportValve.java:102) 
org.apache.catalina.connector.CoyoteAdapter.service(CoyoteAdapter.java:291) 
org.apache.coyote.http11.Http11AprProcessor.process(Http11AprProcessor.java:877) 
org.apache.coyote.http11.Http11AprProtocol$Http11ConnectionHandler.process(Http11AprProtocol.java:594) 
org.apache.tomcat.util.net.AprEndpoint$Worker.run(AprEndpoint.java:1675) 
java.lang.Thread.run(Thread.java:662) 

注根源的完整堆栈跟踪是可用Apache Tomcat/6.0.33日志。

web.xml为REST servlet的部分看起来像这样:

<servlet> 
<servlet-name>jersey</servlet-name> 
<servlet-class>org.codehaus.enunciate.modules.jersey.EnunciateSpringServlet</servlet-class> 
<init-param> 
    <param-name>org.codehaus.enunciate.modules.jersey.config.ServletPath</param-name> 
    <param-value>/rest</param-value> 

</init-param> 

有什么我需要在这里修复的配置,可以解决这个问题?

回答

1

java.lang.NoSuchMethodError:org.objectweb.asm.ClassReader.accept(Lorg /对象式/ ASM/ClassVisitor;我)V com.sun.jersey.impl.container.config.AnnotatedClassScanner.analyzeClassFile(AnnotatedClassScanner.java :267)

在类路径匹配泽西岛需要你的asm吗?

尝试检查

2

java.lang.NoSuchMethodError:发生时,你有类/罐的错误版本(可能是较新的版本/旧版本)在类路径文件。确保你在classpath中的jar是支持的版本。

0

这也可能是因为构建路径中有重复的jar。如果您使用的是Maven,我建议您执行一个依赖项:tree来确定是否有重复项。同时打开你的.classpath文件并检查构建路径问题。