Class DefaultAdvisorAutoProxyCreator

All Implemented Interfaces:
Serializable, AopInfrastructureBean, Aware, BeanClassLoaderAware, BeanFactoryAware, BeanNameAware, BeanPostProcessor, InstantiationAwareBeanPostProcessor, SmartInstantiationAwareBeanPostProcessor, Ordered

public class DefaultAdvisorAutoProxyCreator extends AbstractAdvisorAutoProxyCreator implements BeanNameAware
BeanPostProcessor implementation that creates AOP proxies based on all candidate Advisors in the current BeanFactory. This class is completely generic; it contains no special code to handle any particular aspects, such as pooling aspects.

It's possible to filter out advisors - for example, to use multiple post processors of this type in the same factory - by setting the usePrefix property to true, in which case only advisors beginning with the DefaultAdvisorAutoProxyCreator's bean name followed by a dot (like "aapc.") will be used. This default prefix can be changed from the bean name by setting the advisorBeanNamePrefix property. The separator (.) will also be used in this case.

Author:
Rod Johnson, Rob Harrop
See Also:
  • Field Details

    • SEPARATOR

      public static final String SEPARATOR
      Separator between prefix and remainder of bean name.
      See Also:
  • Constructor Details

    • DefaultAdvisorAutoProxyCreator

      public DefaultAdvisorAutoProxyCreator()
  • Method Details

    • setUsePrefix

      public void setUsePrefix(boolean usePrefix)
      Set whether to only include advisors with a certain prefix in the bean name.

      Default is false, including all beans of type Advisor.

      See Also:
    • isUsePrefix

      public boolean isUsePrefix()
      Return whether to only include advisors with a certain prefix in the bean name.
    • setAdvisorBeanNamePrefix

      public void setAdvisorBeanNamePrefix(@Nullable String advisorBeanNamePrefix)
      Set the prefix for bean names that will cause them to be included for auto-proxying by this object. This prefix should be set to avoid circular references. Default value is the bean name of this object + a dot.
      Parameters:
      advisorBeanNamePrefix - the exclusion prefix
    • getAdvisorBeanNamePrefix

      @Nullable public String getAdvisorBeanNamePrefix()
      Return the prefix for bean names that will cause them to be included for auto-proxying by this object.
    • setBeanName

      public void setBeanName(String name)
      Description copied from interface: BeanNameAware
      Set the name of the bean in the bean factory that created this bean.

      Invoked after population of normal bean properties but before an init callback such as InitializingBean.afterPropertiesSet() or a custom init-method.

      Specified by:
      setBeanName in interface BeanNameAware
      Parameters:
      name - the name of the bean in the factory. Note that this name is the actual bean name used in the factory, which may differ from the originally specified name: in particular for inner bean names, the actual bean name might have been made unique through appending "#..." suffixes. Use the BeanFactoryUtils.originalBeanName(String) method to extract the original bean name (without suffix), if desired.
    • isEligibleAdvisorBean

      protected boolean isEligibleAdvisorBean(String beanName)
      Consider Advisor beans with the specified prefix as eligible, if activated.
      Overrides:
      isEligibleAdvisorBean in class AbstractAdvisorAutoProxyCreator
      Parameters:
      beanName - the name of the Advisor bean
      Returns:
      whether the bean is eligible
      See Also: