spring AOP配置(XML) 通知 的配置

39 篇文章 0 订阅

通知类型**

AOP的通知类型共5种

  • 前置通知:原始方法执行前执行,如果通知中抛出异常,阻止原始方法运行

    应用:数据校验

  • 后置通知:原始方法执行后执行,无论原始方法中是否出现异常,都将执行通知

    应用:现场清理

  • 返回后通知:原始方法正常执行完毕并返回结果后执行,如果原始方法中抛出异常,无法执行

    应用:返回值相关数据处理

  • 抛出异常后通知:原始方法抛出异常后执行,如果原始方法没有抛出异常,无法执行

    应用:对原始方法中出现的异常信息进行处理

  • 环绕通知:在原始方法执行前后均有对应执行执行,还可以阻止原始方法的执行

    应用:十分强大,可以做任何事情

aop:before
  • 名称:aop:before
  • 类型:标签
  • 归属:aop:aspect标签
  • 作用:设置前置通知
  • 格式:
- <aop:aspect ref="adviceId">
    <aop:before method="methodName" pointcut="……"/>
</aop:aspect>
  • 说明:一个aop:aspect标签中可以配置多个aop:before标签

  • 基本属性:

    • method :在通知类中设置当前通知类别对应的方法
    • pointcut :设置当前通知对应的切入点表达式,与pointcut-ref属性冲突
    • pointcut-ref :设置当前通知对应的切入点id,与pointcut属性冲突
aop:after
  • 名称:aop:after
  • 类型:标签
  • 归属:aop:aspect标签
  • 作用:设置后置通知
  • 格式:
- <aop:aspect ref="adviceId">
    <aop:after method="methodName" pointcut="……"/>
</aop:aspect>
  • 说明:一个aop:aspect标签中可以配置多个aop:after标签
  • 基本属性:
    • method :在通知类中设置当前通知类别对应的方法
    • pointcut :设置当前通知对应的切入点表达式,与pointcut-ref属性冲突
    • pointcut-ref :设置当前通知对应的切入点id,与pointcut属性冲突
aop:after-returning
  • 名称:aop:after-returning

  • 类型:标签

  • 归属:aop:aspect标签

  • 作用:设置返回后通知

  • 格式:

    <aop:aspect ref="adviceId">
        <aop:after-returning method="methodName" pointcut="……"/>
    </aop:aspect>
    
  • 说明:一个aop:aspect标签中可以配置多个aop:after-returning标签

  • 基本属性:

    • method :在通知类中设置当前通知类别对应的方法
    • pointcut :设置当前通知对应的切入点表达式,与pointcut-ref属性冲突
    • pointcut-ref :设置当前通知对应的切入点id,与pointcut属性冲突
aop:after-throwing
  • 名称:aop:after-throwing

  • 类型:标签

  • 归属:aop:aspect标签

  • 作用:设置抛出异常后通知

  • 格式:

    <aop:aspect ref="adviceId">
        <aop:after-throwing method="methodName" pointcut="……"/>
    </aop:aspect>
    
    
  • 说明:一个aop:aspect标签中可以配置多个aop:after-throwing标签

  • 基本属性:

    • method :在通知类中设置当前通知类别对应的方法
    • pointcut :设置当前通知对应的切入点表达式,与pointcut-ref属性冲突
    • pointcut-ref :设置当前通知对应的切入点id,与pointcut属性冲突
aop:around
  • 名称:aop:around

  • 类型:标签

  • 归属:aop:aspect标签

  • 作用:设置环绕通知

  • 格式:

    <aop:aspect ref="adviceId">
        <aop:around method="methodName" pointcut="……"/>
    </aop:aspect>
    userService.save()
    
  • 说明:一个aop:aspect标签中可以配置多个aop:around标签

  • 基本属性:

    • method :在通知类中设置当前通知类别对应的方法
    • pointcut :设置当前通知对应的切入点表达式,与pointcut-ref属性冲突
    • pointcut-ref :设置当前通知对应的切入点id,与pointcut属性冲突

环绕通知的开发方式

环绕通知是在原始方法的前后添加功能,在环绕通知中,存在对原始方法的显式调用

public Object around(ProceedingJoinPoint pjp) throws Throwable {
    sout("前置")
    Object ret = pjp.proceed();//userService.save()
    sout("后置")
    return ret;
}
  • 环绕通知方法相关说明:

    • 方法须设定Object类型的返回值,否则会拦截原始方法的返回。如果原始方法返回值类型为void,通知方 也可以设定返回值类型为void,最终返回null

    • 方法需在第一个参数位置设定ProceedingJoinPoint对象,通过该对象调用proceed()方法,实现对原始方法的调用。如省略该参数,原始方法将无法执行

    • 使用proceed()方法调用原始方法时,因无法预知原始方法运行过程中是否会出现异常,强制抛出Throwable对象,封装原始方法中可能出现的异常信息

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

普希托夫

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值