AspectJ 的 5 大通知类型

20 篇文章 0 订阅

目录

五种类型的通知(advice):

参数规则

示例


 

五种类型的通知(advice):

  1. @Before:在目标方法执行之前执行的通知。
  2. @AfterReturning:在目标方法成功执行之后执行的通知。
  3. @AfterThrowing:在目标方法抛出异常退出时执行的通知。
  4. @After:在目标方法退出时执行的通知(无论正常返回还是异常退出)。
  5. @Around:在目标方法执行前后执行的通知,它可以控制是否继续执行目标方法。

参数规则

     AspectJ 的通知方法不能随意指定参数,它们需要遵循一定的参数规则:

  1. @Before, @After, @AfterReturning, @AfterThrowing

    • 这些通知可以没有参数,但如果需要访问目标方法的参数或其他绑定值,必须通过切点表达式来声明它们。
    • 可以通过 args() 指示符绑定目标方法的参数。
    • 可以通过 @target()@args()@within()@annotation() 等指示符绑定其他特定的值。
    • 对于 @AfterReturning 和 @AfterThrowing,可以通过设置 returning 或 throwing 属性来访问返回值或异常对象。
  2. @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 的通知方法参数需要根据切点表达式的需要来指定,不能随意选择参数。这样做是为了确保通知能够正确地织入到目标方法,并访问到所需的数据。

 

  • 7
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值