AspectJ Pointcut para introspectar un código de método local e imprimir una variable dentro del método local
Pregunta
Estoy tratando de escribir un punto y un consejo que podría imprimir una cadena del siguiente método:
public CustomerDto getCustomer(Integer customerCode){
CustomerDto customerDto = new CustomerDto();
String emailID =getEmailAddress();
customerDto.setEmailAddress(emailID);
customerDto.setEmployer(getEmployer());
customerDto.setSpouseName(getSpouse());
return customerDto;
}
No puedo encontrar una forma en la que un pointcut mire String emailID y luego imprima el valor del mismo en un consejo.
Solución
Quizás necesite algo como lo siguiente:
public privileged aspect LocalMethodCallAspect {
private pointcut localMethodExecution() : withincode(public CustomerDto TargetClass.getCustomer(Integer)) &&
call(private String TargetClass.getEmailAddress());
after() returning(String email) : localMethodExecution()
{
System.out.println(email);
}
}
Donde TargetClass
es una clase que contiene los métodos getCustomer()
y getEmailAddress()
.
O lo mismo usando @AspectJ:
@Aspect
public class LocalMethodCallAnnotationDrivenAspect {
@Pointcut("withincode(public CustomerDto TargetClass.getCustomer(Integer)) && " +
"call(private String TargetClass.getEmailAddress())")
private void localMethodExecution() {
}
@AfterReturning(pointcut="localMethodExecution()",returning="email")
public void printingEmail(String email) {
System.out.println(email);
}
}
Licenciado bajo: CC-BY-SA con atribución
No afiliado a StackOverflow