Frage
Entwickeln eines REST-Dienstes mit Datei-Upload-Funktion mit Resteasy, nachdem eine multipartabhängige Resteasy-Abhängigkeit hinzugefügt wurde.
PS: resteasy-jaxrs und resteasy-multipart Version 2.2.1.GA verwenden
SEVERE: Exception sending context initialized event to listener instance of class
org.jboss.resteasy.plugins.server.servlet.ResteasyBootstrap
java.lang.RuntimeException: Unable to scan WEB-INF for JAX-RS annotations,
you must manually register your classes/resources
//...
at org.apache.catalina.startup.Bootstrap.start(Bootstrap.java:289)
at org.apache.catalina.startup.Bootstrap.main(Bootstrap.java:414)
Caused by: java.io.EOFException: Unexpected end of ZLIB input stream
at java.util.zip.InflaterInputStream.fill(InflaterInputStream.java:223)
at java.util.zip.InflaterInputStream.read(InflaterInputStream.java:141)
at java.util.zip.ZipInputStream.read(ZipInputStream.java:146)
//...
at org.scannotation.AnnotationDB.scanClass(AnnotationDB.java:343)
at org.scannotation.AnnotationDB.scanArchives(AnnotationDB.java:326)
at org.jboss.resteasy.plugins.server.servlet.ConfigurationBootstrap
.createDeployment(ConfigurationBootstrap.java:163)
... 17 more
09 Julai 2011 1:52:13 PM org.apache.catalina.core.StandardContext listenerStop
SEVERE: Exception sending context destroyed event to listener instance of class
org.jboss.resteasy.plugins.server.servlet.ResteasyBootstrap
java.lang.NullPointerException
at org.jboss.resteasy.plugins.server.servlet.ResteasyBootstrap.contextDestroyed...
Lösung
Nicht sicher, was die Ursache ist, zwei Lösungen:
1. Downgrade-Version
Beim Downgrade von " resteasy-multipart-provider " auf Version 2.2.0.GA wird das Problem gelöst.
<dependency>
<groupId>org.jboss.resteasy</groupId>
<artifactId>resteasy-jaxrs</artifactId>
<version>2.2.1.GA</version>
</dependency>
<dependency>
<groupId>org.jboss.resteasy</groupId>
<artifactId>resteasy-multipart-provider</artifactId>
<version>2.2.0.GA</version>
</dependency>
2. RESTEasy manuell registrieren
Deaktivieren Sie den automatischen Scan-Service von RESTEasy und registrieren Sie ihn manuell.
Nicht sicher warum, aber es funktioniert.
Datei: web.xml
<!-- disabled auto scan mode
<context-param>
<param-name>resteasy.scan</param-name>
<param-value>true</param-value>
</context-param>
-->
<context-param>
<param-name>resteasy.resources</param-name>
<param-value>your REST service</param-value>
</context-param>