0

我在独立的 Grizzly 网络服务器上使用 Jersey 2。HK2 用于 CDI。我想获得一项将@PerLookup-scope 注入球衣的服务ContainerRequestFilter

服务:

import org.glassfish.hk2.api.PerLookup;
import org.jvnet.hk2.annotations.Service;

@Service
@PerLookup
public class SessionManager {

    [...]
}

过滤器:

import javax.annotation.Priority;
import javax.inject.Inject;
import javax.ws.rs.Priorities;
import javax.ws.rs.container.ContainerRequestContext;
import javax.ws.rs.container.ContainerRequestFilter;
import javax.ws.rs.container.PreMatching;
import javax.ws.rs.ext.Provider;

@Provider
@Priority(Priorities.AUTHENTICATION)
@PreMatching
public class HttpSessionFilter implements ContainerRequestFilter {
    @Inject
    private javax.inject.Provider<org.glassfish.grizzly.http.server.Request> requestProvider;

    @Inject
    private SessionManager sessionManager;

    [...]

}

我的问题是这样的:

  • 过滤器被实例化一次(在启动时)
  • 服务注入一次(在过滤器启动时)
  • 从那里下游的所有事情都在单例范围内有效地发生

问题:如何获得每个请求注入的服务?

更新

建议的使用方法@Inject javax.inject.Provider<SessionManager> sessionManagerProvider对我来说是合乎逻辑的,但sessionManagerProvider.get()返回 null。

hk2 serviceLocator 通过 inhabitant-generator 填充。它报告:

SystemDescriptor(
    implementation=com.skalio.skaliopush.http.SessionManager
    contracts={com.skalio.skaliopush.http.SessionManager}
    scope=org.glassfish.hk2.api.PerLookup
    qualifiers={}
    descriptorType=CLASS
    descriptorVisibility=NORMAL
    metadata=
    rank=0
    loader=null
    proxiable=null
    proxyForSameScope=null
    analysisName=null
    id=31
    locatorId=0
    identityHashCode=494317290
    reified=false)

如果我添加显式绑定,那么它也会像这样找到:

SystemDescriptor(
    implementation=com.skalio.skaliopush.http.SessionManager
    contracts={com.skalio.skaliopush.http.SessionManager}
    scope=org.glassfish.jersey.process.internal.RequestScoped
    qualifiers={}
    descriptorType=CLASS
    descriptorVisibility=NORMAL
    metadata=
    rank=0
    loader=org.glassfish.hk2.utilities.binding.AbstractBinder$2@78b729e6
    proxiable=null
    proxyForSameScope=null
    analysisName=null
    id=39
    locatorId=0
    identityHashCode=2041416495
    reified=false)

第二次更新

我正在使用两个服务定位器:一个显式创建,并通过 HK2 居民生成器填充;和泽西创造的那个。它们通过BridgingInjectionResolver 连接

当我将显式绑定添加到泽西岛的服务定位器时,@peeskillet 的响应有效。将绑定添加到其他服务定位器会导致上述结果(sessionManagerProvider.get()返回 null)。

4

1 回答 1

0

如果你也使用它应该可以工作javax.inject.Provider<SessionMananger>。默认范围是每次查找。但我想你需要懒惰地加载它。

不知道它在功能上与RequestScoped泽西岛有何不同。我认为在一个PerLookup范围内,如果我将它一次注入过滤器和一次注入资源类,它将被创建两次,但现在只是测试,即使在PerLookup范围内,它仍然只为每个请求创建一次。

或者,为了确定,您可能只想将它绑定到 aRequestScoped如果那是您真正想要的。

register(new AbstractBinder(){
    protected void configure() {
        bind(SessionManager.class).to(SessionManager.class)
                                  .in(RequestScoped.class);
    }
});
于 2015-09-15T16:24:09.157 回答