用两种可能的实现定义 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 在代码中的其他任何位置注入正确的实现。