Dropwizard HK2注射剂

Mat*_*rno 3 java dependency-injection jersey dropwizard hk2

我在与dropwizard一起工作时还很新。目前,我正在尝试实施HK2依赖项注入。在资源内部可以很好地工作,但是在资源外部不能工作。这是我在做什么:

Client client = new JerseyClientBuilder(environment).using(configuration.getJerseyClientConfiguration()).build("contentmoduleservice");

    //DAOs
    ContentModuleDAO contentModuleDAO = new ContentModuleDAO(hibernate.getSessionFactory());
    ModuleServedDAO moduleServedDAO = new ModuleServedDAO(hibernate.getSessionFactory());

    //Manager
    ContentModuleManager moduleManager = new ContentModuleManager();
    EntityTagManager eTagManager = new EntityTagManager();
    ProposalManager proposalManager = new ProposalManager(client, configuration);

    environment.jersey().register(new AbstractBinder() {
        @Override
        protected void configure() {
            bind(eTagManager).to(EntityTagManager.class);
            bind(contentModuleDAO).to(ContentModuleDAO.class);
            bind(moduleServedDAO).to(ModuleServedDAO.class);
            bind(proposalManager).to(ProposalManager.class);
            bind(moduleManager).to(ContentModuleManager.class);
        }
    });
Run Code Online (Sandbox Code Playgroud)

我创建要注入的类的实例并绑定它们。

在我的资源中,注入工作:

@Api
@Path("/api/contentmodule")
public class ContentModuleResource {

    static final Logger LOG = LoggerFactory.getLogger(ContentModuleResource.class);
    static final int MAX_PROPOSALS_PER_MODULE = 10;

    @Inject
    private ContentModuleDAO contentModuleDAO;

    @Inject
    private EntityTagManager eTagManager;

    @Inject
    private ProposalManager proposalManager;

    @Inject
    private ContentModuleManager contentModuleManager;
Run Code Online (Sandbox Code Playgroud)

所有这些变量都填充有正确类的实例。

问题是:ContentModuleManager还应该通过注入来获取其中一些类:

public class ContentModuleManager {

@Inject
private ContentModuleDAO contentModuleDAO;

@Inject
private ProposalManager proposalManager;

@Inject
private ModuleServedDAO moduleServedDAO;
Run Code Online (Sandbox Code Playgroud)

但是这些都是空的。有人可以解释为什么这个问题会发生,我该如何解决?:D

谢谢!

Pau*_*tha 5

如果您要自己实例化服务,那么它将不会经历DI生命周期,并且永远不会被注入。如果您只是将服务注册为类,则可以让容器创建服务

bind(ContentModuleManager.class)
    .to(ContentModuleManager.class)
    .in(Singleton.class);
Run Code Online (Sandbox Code Playgroud)

另一方面,如果您自己创建所有服务,并且所有服务都可用,那么为什么不根本不使用DI容器呢?只需通过构造函数传递所有服务即可。无论是使用构造函数注入1还是手动传递构造函数,通过构造函数获取服务都是一种好习惯,因为它可以简化对服务的测试。


1-构造函数注入

private Service service;

@Inject
public OtherService(Service service) {
   this.service = service;
}
Run Code Online (Sandbox Code Playgroud)