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