当试图实现一个负责捕获和记录某种类型的错误的方面时,我最初认为这可以使用 AfterThrowing 建议。然而,他的建议似乎没有捕捉到异常,而只是提供了一个额外的入口点来处理异常。
唯一能捕获有问题的异常的建议将是一个 AroundAdvice——要么是那个,要么是我做错了什么。
任何人都可以断言,如果我想捕捉异常,我必须使用 AroundAdvice 吗?我使用的配置如下:
@Pointcut("execution(* test.simple.OtherService.print*(..))")
public void printOperation() {}
@AfterThrowing(pointcut="printOperation()", throwing="exception")
public void logException(Throwable exception) {
System.out.println(exception.getMessage());
}
@Around("printOperation()")
public void swallowException(ProceedingJoinPoint pjp) throws Throwable {
try {
pjp.proceed();
} catch (Throwable exception) {
System.out.println(exception.getMessage());
}
}
请注意,在此示例中,我捕获了所有异常,因为它只是一个示例。我知道吞下所有异常是不好的做法,但是对于我当前的用例,我希望只记录一种特殊类型的异常,同时避免重复的日志记录逻辑。