The following bean types are registered by either of these custom tags:
| Bean | Purpose | 
|---|---|
| ConfigurationClassPostProcessor | A bean factory post processor used for bootstrapping classes annotated with @Configuration | 
| AutowiredAnnotationBeanPostProcessor | A bean post processor which processes fields, setter methods, arbitrary methods annotated with @AutoWired, @Value and supports JSR-330 @Inject annotation | 
| RequiredAnnotationBeanPostProcessor | A bean post processor which enforces that the required bean properties have been set - by looking for fields annotated with @Required annotation | 
| CommonAnnotationBeanPostProcessor | A bean post processor which supports JSR-250 annotations - eg. @Resource | 
| PersistenceAnnotationBeanPostProcessor | A bean post processor that processes @PersistenceUnit and @PersistenceContext annotations for injecting in a EntityManagerFactory and EntityManager respectively. | 
This is the reason why if component-scan is present, annotation-config can be kept out.
If for some reason this registration of default bean definitions are to be avoided, the way to do that is to specify an additional "annotation-config" attribute in component-scan, this way:
<context:component-scan basePackages=".." annotation-config="false"/>
Reference:
Spring Reference site
 
No comments:
Post a Comment