gpt4 book ai didi

java - 构造函数注入(inject)不适用于 @Statless bean 中的限定符

转载 作者:太空宇宙 更新时间:2023-11-04 10:36:44 25 4
gpt4 key购买 nike

我遇到了下一个令人兴奋的问题。如果我尝试在 Weblogic 12.2.1.3.0 上运行下一个代码:

<小时/>
package hu.sample.bean;

import lombok.extern.slf4j.Slf4j;

import javax.ejb.Stateless;
import javax.inject.Inject;
import java.util.Random;

@Slf4j
@Stateless
public class Salutatory {

private Butler butler;
private Butler assistant;

public Salutatory() {}

@Inject
public Salutatory(@MainButler Butler mainButler,
@Assistant Butler assistant) {
this.butler = mainButler;
this.assistant = assistant;
log.debug("Call with {} {}", mainButler, assistant);
}

public String salute(String name) {
if (new Random().nextBoolean()) {
return butler.welcome(name + "1");
} else {
return assistant.welcome(name + "2");
}
}
}
<小时/>
package hu.sample.bean;

public interface Butler {

String welcome(String name);
}
<小时/>
package hu.sample.bean;

import javax.inject.Qualifier;

import java.lang.annotation.Retention;
import java.lang.annotation.Target;

import static java.lang.annotation.ElementType.*;
import static java.lang.annotation.RetentionPolicy.RUNTIME;

@Qualifier
@Retention(RUNTIME)
@Target({TYPE, METHOD, FIELD, PARAMETER})
public @interface MainButler {
}
<小时/>
package hu.sample.bean;

import javax.inject.Qualifier;
import java.lang.annotation.Retention;
import java.lang.annotation.Target;

import static java.lang.annotation.ElementType.*;
import static java.lang.annotation.RetentionPolicy.RUNTIME;

@Qualifier
@Retention(RUNTIME)
@Target({TYPE, METHOD, FIELD, PARAMETER})
public @interface Assistant {
}
<小时/>
package hu.sample.bean;

import javax.ejb.Stateless;
import javax.enterprise.inject.Alternative;
import javax.enterprise.inject.Any;
import javax.inject.Named;

@Stateless
@MainButler
public class George implements Butler {

@Override
public String welcome(String name) {
return String.format("Hello, I'm Geroge, I'm the main butler. Welcom here %s! (%s)", name, this.getClass());
}
}
<小时/>
package hu.sample.bean;

import javax.ejb.Stateless;

@Stateless
@Assistant
public class Peter implements Butler {

@Override
public String welcome(String name) {
return String.format("Hello, I'm Peter, I'm an assistant. Welcom here %s! (%s)", name, this.getClass());
}
}

我得到下一个异常:

weblogic.management.DeploymentException: CDI deployment failure:WELD-001408: Unsatisfied dependencies for type Butler with qualifiers @Default
at injection point [BackedAnnotatedParameter] Parameter 1 of [BackedAnnotatedConstructor] public hu.sample.bean.Salutatory_mv77ws_Impl(Butler, Butler)
at hu.sample.bean.Salutatory_mv77ws_Impl.<init>(Salutatory_mv77ws_Impl.java:0)
WELD-001475: The following beans match by type, but none have matching qualifiers:
- Session bean [class hu.sample.bean.Peter with qualifiers [@Assistant @Any]; local interfaces are [Butler],
- Session bean [class hu.sample.bean.George with qualifiers [@MainButler @Any]; local interfaces are [Butler]

好的,我明白了这一点,并且我创建了 Butler 的默认实现。但在这种情况下,CDI 每次都会注入(inject)默认实现,忽略限定符。为什么?

如果我使用 setter 注入(inject)、字段注入(inject)等,限定符效果很好......

如果 Salutatory 是 @WebServlet,带有限定符的构造函数注入(inject)也可以很好地工作。

但是,为什么带有限定符的构造函数注入(inject)在 @Stateless bean 中不能很好地工作?

非常感谢您的回答!

最佳答案

要注入(inject) EJB,最好在 EJB 注入(inject)上下文中使用 javax.ejb.EJB 注释。 (即注入(inject)点是 EJB 本身)

在这种情况下,您可以使用类的简单名称作为 beanName 来选择要注入(inject)的实现。

在您的情况下,不要在构造函数中限定 bean,而是对每个字段进行限定。


@EJB(beanName="George")
private Butler butler;

@EJB(beanName="Peter")
private Butler assistant;

关于java - 构造函数注入(inject)不适用于 @Statless bean 中的限定符,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49384168/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com