Für das Leben von mir kann ich Jersey mit hk2 nicht bekommen, @Service annotierte Klassen automatisch zu entdecken und sie zu injizieren. Ich habe versucht, alle Ratschläge zu Stapelüberlauf, Trikot und hk2 Dokumentation zu befolgen und immer noch kein Glück. Ich versuche, einen einfachen Echo-Service in eine Jersey-Ressource zu injizieren. Das Skelett wird aus dem einfachen Webapp-Maven-Archetyp für Jersey generiert, den ich zu erweitern versuchte. Das ist, was ich habe, so weit:Jersey Hk2 injecting @Service annotierte Klassen
pom.xml
<build>
<finalName>sandbox</finalName>
<plugins>
<plugin>
<groupId>org.glassfish.hk2</groupId>
<artifactId>hk2-inhabitant-generator</artifactId>
<version>2.3.0</version>
<executions>
<execution>
<configuration>
<verbose>true</verbose>
</configuration>
<goals>
<goal>generate-inhabitants</goal>
</goals>
</execution>
</executions>
</plugin>
</plugins>
</build>
...
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.glassfish.jersey</groupId>
<artifactId>jersey-bom</artifactId>
<version>${jersey.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
<dependencies>
<dependency>
<groupId>org.glassfish.jersey.containers</groupId>
<artifactId>jersey-container-servlet-core</artifactId>
</dependency>
<dependency>
<groupId>org.glassfish.hk2</groupId>
<artifactId>hk2</artifactId>
<version>2.3.0</version>
</dependency>
</dependencies>
web.xml
<servlet>
<servlet-name>Jersey Web Application</servlet-name>
<servlet-class>org.glassfish.jersey.servlet.ServletContainer</servlet-class>
<init-param>
<param-name>jersey.config.server.provider.packages</param-name>
<param-value>my.package.jerseytest</param-value>
</init-param>
<init-param>
<param-name>javax.ws.rs.Application</param-name>
<param-value>my.package.jerseytest.application.Application</param-value>
</init-param>
<load-on-startup>1</load-on-startup>
</servlet>
my.package.jerseytest.application.Application
public class Application extends ResourceConfig {
public Application() {
ServiceLocator locator = ServiceLocatorUtilities.createAndPopulateServiceLocator();
}
}
meine. package.jerseytest.service.EchoService
@Service
public class EchoService {
public String generateResponse(String echo) {
return echo;
}
}
my.package.jerseytest.resource.MyResource
@Path("myresource")
public class MyResource {
@Inject
EchoService echoService;
@GET
@Produces(MediaType.TEXT_PLAIN)
public String getIt() {
return echoService.generateResponse("Got it!");
}
}
Ich habe überprüft, dass der inhibitant-Generator in der Tat laufen und dessen Ausgang erzeugen, doch wenn der Server SCHRITTE http://localhost:8080/sandbox/webapi/myresource
Tomcat läuft ich
SEVERE: Servlet.service() for servlet [Jersey Web Application] in context with path [/sandbox] threw exception [A MultiException has 3 exceptions. They are:
1. org.glassfish.hk2.api.UnsatisfiedDependencyException: There was no object available for injection at SystemInjecteeImpl(requiredType=EchoService,parent=MyResource,qualifiers={},position=-1,optional=false,self=false,unqualified=null,932014249)
2. java.lang.IllegalArgumentException: While attempting to resolve the dependencies of my.package.jerseytest.resource.MyResource errors were found
3. java.lang.IllegalStateException: Unable to perform operation: resolve on my.package.jerseytest.resource.MyResource
] with root cause
org.glassfish.hk2.api.UnsatisfiedDependencyException: There was no object available for injection at SystemInjecteeImpl(requiredType=EchoService,parent=MyResource,qualifiers={},position=-1,optional=false,self=false,unqualified=null,932014249)
Irgendwelche Ideen, die ich vermisse? Ich würde schätzen jede Hilfe :(
NB! Ich weiß, über
- How does ServiceLocator find @Service and @Contact automatically in HK2?
- HK2 annotations not being handled
- https://hk2.java.net/inhabitant-generator.html
- https://hk2.java.net/2.2.0-b25/getting-started.html
- https://java.net/jira/browse/HK2-165
aber sie haben mir nicht geholfen ...
etwas Glück dazu? –
Nein, gab auf. Es gab etwas über zwei verschiedene Versionen der @Inject-Annotation, aber das Projekt ging an diesem vorbei und wir entschieden uns für die Spring Bridge von Spring und den Spring DI-Container. –
Nur neugierig, warum nicht einfach CDI? – ymajoros