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