Puede ser tarde, pero me encontré con algo que explica su preocupación relacionada con el proxy (solo se interceptarán las llamadas de método 'externas' que ingresen a través del proxy).
Por ejemplo, tienes una clase que se ve así
@Component("mySubordinate")
public class CoreBusinessSubordinate {
public void doSomethingBig() {
System.out.println("I did something small");
}
public void doSomethingSmall(int x){
System.out.println("I also do something small but with an int");
}
}
y tienes un aspecto que se ve así:
@Component
@Aspect
public class CrossCuttingConcern {
@Before("execution(* com.intertech.CoreBusinessSubordinate.*(..))")
public void doCrossCutStuff(){
System.out.println("Doing the cross cutting concern now");
}
}
Cuando lo ejecutas así:
@Service
public class CoreBusinessKickOff {
@Autowired
CoreBusinessSubordinate subordinate;
// getter/setters
public void kickOff() {
System.out.println("I do something big");
subordinate.doSomethingBig();
subordinate.doSomethingSmall(4);
}
}
Resultados de llamar a kickOff arriba del código dado arriba.
I do something big
Doing the cross cutting concern now
I did something small
Doing the cross cutting concern now
I also do something small but with an int
pero cuando cambias tu código a
@Component("mySubordinate")
public class CoreBusinessSubordinate {
public void doSomethingBig() {
System.out.println("I did something small");
doSomethingSmall(4);
}
public void doSomethingSmall(int x){
System.out.println("I also do something small but with an int");
}
}
public void kickOff() {
System.out.println("I do something big");
subordinate.doSomethingBig();
//subordinate.doSomethingSmall(4);
}
Verá, el método llama internamente a otro método para que no se intercepte y la salida se vería así:
I do something big
Doing the cross cutting concern now
I did something small
I also do something small but with an int
Puedes evitar esto haciendo eso
public void doSomethingBig() {
System.out.println("I did something small");
//doSomethingSmall(4);
((CoreBusinessSubordinate) AopContext.currentProxy()).doSomethingSmall(4);
}
Fragmentos de código tomados de:
https://www.intertech.com/Blog/secrets-of-the-spring-aop-proxy/