目录
五种类型的通知(advice):
- @Before:在目标方法执行之前执行的通知。
- @AfterReturning:在目标方法成功执行之后执行的通知。
- @AfterThrowing:在目标方法抛出异常退出时执行的通知。
- @After:在目标方法退出时执行的通知(无论正常返回还是异常退出)。
- @Around:在目标方法执行前后执行的通知,它可以控制是否继续执行目标方法。
参数规则
AspectJ 的通知方法不能随意指定参数,它们需要遵循一定的参数规则:
-
@Before, @After, @AfterReturning, @AfterThrowing:
- 这些通知可以没有参数,但如果需要访问目标方法的参数或其他绑定值,必须通过切点表达式来声明它们。
- 可以通过
args()
指示符绑定目标方法的参数。 - 可以通过
@target()
,@args()
,@within()
,@annotation()
等指示符绑定其他特定的值。 - 对于
@AfterReturning
和@AfterThrowing
,可以通过设置returning
或throwing
属性来访问返回值或异常对象。
-
@Around:
- 必须有一个
ProceedingJoinPoint
类型的参数,这是调用目标方法的入口。 - 其他参数规则与
@Before
,@After
,@AfterReturning
,@AfterThrowing
类似。
- 必须有一个
示例
@Before("execution(* com.example.service.*.*(..)) && args(param1, param2)")
public void beforeAdvice(JoinPoint joinPoint, Object param1, Object param2) {
// 代码实现
}
@AfterReturning(pointcut="execution(* com.example.service.*.*(..))", returning="result")
public void afterReturningAdvice(JoinPoint joinPoint, Object result) {
// 代码实现
}
@AfterThrowing(pointcut="execution(* com.example.service.*.*(..))", throwing="ex")
public void afterThrowingAdvice(JoinPoint joinPoint, Throwable ex) {
// 代码实现
}
@After("execution(* com.example.service.*.*(..))")
public void afterAdvice(JoinPoint joinPoint) {
// 代码实现
}
@Around("execution(* com.example.service.*.*(..)) && args(param1, param2)")
public Object aroundAdvice(ProceedingJoinPoint pjp, Object param1, Object param2) throws Throwable {
// 代码实现
}
在这些示例中,通知方法的参数与目标方法的参数、返回值或异常对象相关联,并且通过切点表达式来指定要绑定的参数。
总结起来,AspectJ 的通知方法参数需要根据切点表达式的需要来指定,不能随意选择参数。这样做是为了确保通知能够正确地织入到目标方法,并访问到所需的数据。