public class AnnotationAwareAspectJAutoProxyCreator extends AspectJAwareAdvisorAutoProxyCreator
AspectJAwareAdvisorAutoProxyCreator subclass that processes all AspectJ
 annotation aspects in the current application context, as well as Spring Advisors.
 Any AspectJ annotated classes will automatically be recognized, and their advice applied if Spring AOP's proxy-based model is capable of applying it. This covers method execution joinpoints.
If the <aop:include> element is used, only @AspectJ beans with names matched by an include pattern will be considered as defining aspects to use for Spring auto-proxying.
Processing of Spring Advisors follows the rules established in
 AbstractAdvisorAutoProxyCreator.
AspectJAdvisorFactory, 
Serialized FormDO_NOT_PROXY, logger, PROXY_WITHOUT_ADDITIONAL_INTERCEPTORSHIGHEST_PRECEDENCE, LOWEST_PRECEDENCE| Constructor and Description | 
|---|
| AnnotationAwareAspectJAutoProxyCreator() | 
| Modifier and Type | Method and Description | 
|---|---|
| protected List<Advisor> | findCandidateAdvisors()Find all candidate Advisors to use in auto-proxying. | 
| protected void | initBeanFactory(ConfigurableListableBeanFactory beanFactory) | 
| protected boolean | isEligibleAspectBean(String beanName)Check whether the given aspect bean is eligible for auto-proxying. | 
| protected boolean | isInfrastructureClass(Class<?> beanClass)Return whether the given bean class represents an infrastructure class
 that should never be proxied. | 
| void | setAspectJAdvisorFactory(AspectJAdvisorFactory aspectJAdvisorFactory) | 
| void | setIncludePatterns(List<String> patterns)Set a list of regex patterns, matching eligible @AspectJ bean names. | 
extendAdvisors, shouldSkip, sortAdvisorsadvisorsPreFiltered, findAdvisorsThatCanApply, findEligibleAdvisors, getAdvicesAndAdvisorsForBean, isEligibleAdvisorBean, setBeanFactorybuildAdvisors, createProxy, customizeProxyFactory, determineCandidateConstructors, getBeanFactory, getCacheKey, getCustomTargetSource, getEarlyBeanReference, getOrder, isFrozen, postProcessAfterInitialization, postProcessAfterInstantiation, postProcessBeforeInitialization, postProcessBeforeInstantiation, postProcessPropertyValues, predictBeanType, setAdvisorAdapterRegistry, setApplyCommonInterceptorsFirst, setBeanClassLoader, setCustomTargetSourceCreators, setFrozen, setInterceptorNames, setOrder, setProxyClassLoader, shouldProxyTargetClass, wrapIfNecessarycopyFrom, isExposeProxy, isOpaque, isOptimize, isProxyTargetClass, setExposeProxy, setOpaque, setOptimize, setProxyTargetClass, toStringpublic AnnotationAwareAspectJAutoProxyCreator()
public void setIncludePatterns(List<String> patterns)
Default is to consider all @AspectJ beans as eligible.
public void setAspectJAdvisorFactory(AspectJAdvisorFactory aspectJAdvisorFactory)
protected void initBeanFactory(ConfigurableListableBeanFactory beanFactory)
initBeanFactory in class AbstractAdvisorAutoProxyCreatorprotected List<Advisor> findCandidateAdvisors()
AbstractAdvisorAutoProxyCreatorfindCandidateAdvisors in class AbstractAdvisorAutoProxyCreatorprotected boolean isInfrastructureClass(Class<?> beanClass)
AbstractAutoProxyCreatorThe default implementation considers Advices, Advisors and AopInfrastructureBeans as infrastructure classes.
isInfrastructureClass in class AbstractAutoProxyCreatorbeanClass - the class of the beanAdvice, 
Advisor, 
AopInfrastructureBean, 
AbstractAutoProxyCreator.shouldSkip(java.lang.Class<?>, java.lang.String)protected boolean isEligibleAspectBean(String beanName)
If no <aop:include> elements were used then "includePatterns" will be
 null and all beans are included. If "includePatterns" is non-null,
 then one of the patterns must match.