用两种可能的实现定义 bean
Defining bean with two possible implementations
到目前为止,我有一个非常简单的 bean 定义,如下所示:
@Bean
@Conditional(value=ConditionClass.class)
SomeInterface myMethodImpl(){
return new ImplementationOne();
}
但是,我现在遇到的情况是添加了额外的实现 class,我们称它为 ImplementationTwo
,当在配置文件。
所以我需要的是这样的东西:
@Bean
@Conditional(value=ConditionClass.class)
SomeInterface myMethodImpl(){
return context.getEnvironment().getProperty("optionEnabled") ? new
ImplementationOne() : new ImplementationTwo();
}
基本上是一种在 bean 定义时根据配置值实例化正确实现的方法。这可能吗,任何人都可以提供一个例子吗?谢谢
我认为你做错了。
您应该在您的实现上使用 @Conditional()
,而不是在您的界面上。
我会这样做:
您将在代码中使用的界面。
MyInterface.java
public interface MyInterface {
void myMethod();
}
第一个实现:
MyInterfaceImplOne.java
@Bean
@Conditional(MyInterfaceImplOneCondition.class)
public class MyInterfaceImplOne implements MyInterface {
void myMethod(){
// dosmthg
}
}
MyInterfaceImplOneCondition.java
public class MyInterfaceImplOneCondition implements Condition {
@Override
public boolean matches(ConditionContext context, AnnotatedTypeMetadata metadata) {
return context.getEnvironment().getProperty("optionEnabled")
}
}
对于第二次实施:
MyInterfaceImplTwo.java
@Bean
@Conditional(MyInterfaceImplTwoCondition.class)
public class MyInterfaceImplTwo implements MyInterface {
void myMethod(){
// dosmthg 2
}
}
MyInterfaceImplTwoCondition.java
public class MyInterfaceImplTwoCondition implements Condition {
@Override
public boolean matches(ConditionContext context, AnnotatedTypeMetadata metadata) {
return !context.getEnvironment().getProperty("optionEnabled")
}
}
这样的话,你现在只需要调用接口,Spring就会注入符合条件的bean。
希望这就是你要找的,我已经够清楚了!
无需使用 @Conditional
即可实现。
假设您有一个接口 SomeInterface
和两个实现 ImplOne
ImplTwo
:
SomeInterface.java
public interface SomeInterface {
void someMethod();
}
ImplOne.java
public class ImplOne implements SomeInterface{
@Override
public void someMethod() {
// do something
}
}
ImplTwo.java
public class ImplTwo implements SomeInterface{
@Override
public void someMethod() {
// do something else
}
}
然后你可以控制在配置中使用哪个实现 class 像这样:
MyConfig.java
@Configuration
public class MyConfig {
@Autowired
private ApplicationContext context;
@Bean
public SomeInterface someInterface() {
if (this.context.getEnvironment().getProperty("implementation") != null) {
return new ImplementationOne();
} else {
return new ImplementationTwo();
}
}
}
确保 spring 的组件扫描找到 MyConfig
。然后,您可以使用 @Autowired
在代码中的其他任何位置注入正确的实现。
到目前为止,我有一个非常简单的 bean 定义,如下所示:
@Bean
@Conditional(value=ConditionClass.class)
SomeInterface myMethodImpl(){
return new ImplementationOne();
}
但是,我现在遇到的情况是添加了额外的实现 class,我们称它为 ImplementationTwo
,当在配置文件。
所以我需要的是这样的东西:
@Bean
@Conditional(value=ConditionClass.class)
SomeInterface myMethodImpl(){
return context.getEnvironment().getProperty("optionEnabled") ? new
ImplementationOne() : new ImplementationTwo();
}
基本上是一种在 bean 定义时根据配置值实例化正确实现的方法。这可能吗,任何人都可以提供一个例子吗?谢谢
我认为你做错了。
您应该在您的实现上使用 @Conditional()
,而不是在您的界面上。
我会这样做:
您将在代码中使用的界面。
MyInterface.java
public interface MyInterface {
void myMethod();
}
第一个实现:
MyInterfaceImplOne.java
@Bean
@Conditional(MyInterfaceImplOneCondition.class)
public class MyInterfaceImplOne implements MyInterface {
void myMethod(){
// dosmthg
}
}
MyInterfaceImplOneCondition.java
public class MyInterfaceImplOneCondition implements Condition {
@Override
public boolean matches(ConditionContext context, AnnotatedTypeMetadata metadata) {
return context.getEnvironment().getProperty("optionEnabled")
}
}
对于第二次实施:
MyInterfaceImplTwo.java
@Bean
@Conditional(MyInterfaceImplTwoCondition.class)
public class MyInterfaceImplTwo implements MyInterface {
void myMethod(){
// dosmthg 2
}
}
MyInterfaceImplTwoCondition.java
public class MyInterfaceImplTwoCondition implements Condition {
@Override
public boolean matches(ConditionContext context, AnnotatedTypeMetadata metadata) {
return !context.getEnvironment().getProperty("optionEnabled")
}
}
这样的话,你现在只需要调用接口,Spring就会注入符合条件的bean。
希望这就是你要找的,我已经够清楚了!
无需使用 @Conditional
即可实现。
假设您有一个接口 SomeInterface
和两个实现 ImplOne
ImplTwo
:
SomeInterface.java
public interface SomeInterface {
void someMethod();
}
ImplOne.java
public class ImplOne implements SomeInterface{
@Override
public void someMethod() {
// do something
}
}
ImplTwo.java
public class ImplTwo implements SomeInterface{
@Override
public void someMethod() {
// do something else
}
}
然后你可以控制在配置中使用哪个实现 class 像这样:
MyConfig.java
@Configuration
public class MyConfig {
@Autowired
private ApplicationContext context;
@Bean
public SomeInterface someInterface() {
if (this.context.getEnvironment().getProperty("implementation") != null) {
return new ImplementationOne();
} else {
return new ImplementationTwo();
}
}
}
确保 spring 的组件扫描找到 MyConfig
。然后,您可以使用 @Autowired
在代码中的其他任何位置注入正确的实现。