Annotation Interface ConditionalOnMissingBean
@Target({TYPE,METHOD})
@Retention(RUNTIME)
@Documented
@Conditional(org.springframework.boot.autoconfigure.condition.OnBeanCondition.class)
public @interface ConditionalOnMissingBean
@Conditional that only matches when no beans meeting the specified
 requirements are already contained in the BeanFactory. None of the requirements
 must be met for the condition to match and the requirements do not have to be met by
 the same bean.
 
 When placed on a @Bean method, the bean class defaults to the return type of
 the factory method:
 
 @Configuration
 public class MyAutoConfiguration {
     @ConditionalOnMissingBean
     @Bean
     public MyService myService() {
         ...
     }
 }
 
 In the sample above the condition will match if no bean of type MyService is
 already contained in the BeanFactory.
 
The condition can only match the bean definitions that have been processed by the application context so far and, as such, it is strongly recommended to use this condition on auto-configuration classes only. If a candidate bean may be created by another auto-configuration, make sure that the one using this condition runs after.
- Since:
- 1.0.0
- Author:
- Phillip Webb, Andy Wilkinson
- 
Optional Element SummaryOptional ElementsModifier and TypeOptional ElementDescriptionClass<? extends Annotation>[]The annotation type decorating a bean that should be checked.Class<?>[]The class types of beans that should be ignored when identifying matching beans.String[]The class type names of beans that should be ignored when identifying matching beans.String[]The names of beans to check.Class<?>[]Additional classes that may contain the specified bean types within their generic parameters.Strategy to decide if the application context hierarchy (parent contexts) should be considered.String[]The class type names of beans that should be checked.Class<?>[]The class types of beans that should be checked.
- 
Element Details- 
valueClass<?>[] valueThe class types of beans that should be checked. The condition matches when no bean of each class specified is contained in theBeanFactory.- Returns:
- the class types of beans to check
 - Default:
- {}
 
- 
typeString[] typeThe class type names of beans that should be checked. The condition matches when no bean of each class specified is contained in theBeanFactory.- Returns:
- the class type names of beans to check
 - Default:
- {}
 
- 
ignoredClass<?>[] ignoredThe class types of beans that should be ignored when identifying matching beans.- Returns:
- the class types of beans to ignore
- Since:
- 1.2.5
 - Default:
- {}
 
- 
ignoredTypeString[] ignoredTypeThe class type names of beans that should be ignored when identifying matching beans.- Returns:
- the class type names of beans to ignore
- Since:
- 1.2.5
 - Default:
- {}
 
- 
annotationClass<? extends Annotation>[] annotationThe annotation type decorating a bean that should be checked. The condition matches when each annotation specified is missing from all beans in theBeanFactory.- Returns:
- the class-level annotation types to check
 - Default:
- {}
 
- 
nameString[] nameThe names of beans to check. The condition matches when each bean name specified is missing in theBeanFactory.- Returns:
- the names of beans to check
 - Default:
- {}
 
- 
searchSearchStrategy searchStrategy to decide if the application context hierarchy (parent contexts) should be considered.- Returns:
- the search strategy
 - Default:
- ALL
 
- 
parameterizedContainerClass<?>[] parameterizedContainerAdditional classes that may contain the specified bean types within their generic parameters. For example, an annotation declaringvalue=Name.classandparameterizedContainer=NameRegistration.classwould detect bothNameandNameRegistration<Name>.- Returns:
- the container types
- Since:
- 2.1.0
 - Default:
- {}
 
 
-