Spring AOP: исключить избегать выпускных классов и перечислений из pointcut
Я использую попытку реализовать ведение журнала с помощью Spring AOP. Я определил
@Pointcut("execution(* com.mycom..*(..))")
private void framework() {}
@Around("framework()")
public Object aroundAdviceFramework(ProceedingJoinPoint jp) throws Throwable {
if (logger.isDebugEnabled())
logger.debug("DEBUG:: {} {} Enter", jp.getTarget().getClass().getName(), jp.getSignature().getName());
Object returnVal = jp.proceed(jp.getArgs());
if (logger.isDebugEnabled())
logger.debug("DEBUG:: {} {} Out", jp.getTarget().getClass().getName(), jp.getSignature().getName());
logger.info("INFO:: " + jp.getTarget().getClass().getName() + " " + jp.getSignature().getName() + " Finished:");
return returnVal;
}
В пакете mycom и его подпакетах много классов. Некоторые из классов enum и final. Из-за этого я получаю
nested exception is org.springframework.aop.framework.AopConfigException:
Could not generate CGLIB subclass of class [class com.mycom.util.BancsServiceProvider]: Common causes of this problem include using a final class or a non-visible class; nested exception is java.lang.IllegalArgumentException: Cannot subclass final class class com.mycom.util.BancsServiceProvider
at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.doCreateBean(AbstractAutowireCapableBeanFactory.java:529)
Есть ли способ исключить все конечные классы и перечислить классы из журнала, используя какое-то регулярное выражение. Примечание: у меня все перечисленные классы в разных пакетах. Было бы трудно исключить их, используя полные имена классов.
Обновление 2014-11-17 (пробуем решение kriegaex):
Я пытался с помощью
@Pointcut("!within(is(FinalType))")
но я получаю следующую ошибку
Pointcut is not well-formed: expecting ')' at character position 10
! В (является (FinalType))
Я добавил эту maven-зависимость в файл pom
<dependency>
<groupId>org.aspectj</groupId>
<artifactId>aspectjrt</artifactId>
<version>1.8.4</version>
</dependency>
Я также добавил эту зависимость Maven
<dependency>
<groupId>org.aspectj</groupId>
<artifactId>aspectjweaver</artifactId>
<version>1.8.4</version>
</dependency>
Теперь все работает как шарм. Есть идеи, что здесь происходит?