AOP前置/最终通知、不使用接口的前置通知和最终通知

如果不适用接口,那么必须自己定义通知类并在xml配置文件中设置!

不使用接口完成AOP,很大概率Spring使用的是cglib动态代理

Log2.java

package com.atstudy.log;

/**
 * 不使用接口完成AOP,很大概率Spring使用的是cglib动态代理
 */
public class Log2
{
    /**
     * 用于前置通知的方法
     */
    public void before()
    {
        System.out.println("方法调用了...");
    }

    /**
     * 用于最终通知的方法
     */
    public void after()
    {
        System.out.println("方法执行完了...");
    }


}

spring.xml 此处只粘贴关键代码

 <bean id="log2" class="com.atstudy.log.Log2"></bean>

    <!--配置不使用接口的AOP-->
    <aop:config>
        <!--
            在指定切入点使用Log2完成前置通知和后置通知
        -->
        <aop:aspect ref="log2">
            <!--配置切入点-->
            <aop:pointcut id="qrd" expression="execution(* com.atstudy.controller.*.*(..))"/>
            <!--
        
AOP(面向切面编程)是一种编程范式,它允许在程序运行期间动态地将额外的行为织入到代码中。其中,前置通知和环绕通知AOP中的两种常见通知类型。 1. 前置通知(Before Advice):前置通知在目标方法执行之前执行,可以用于执行一些准备工作或者进行参数校验等操作。在AOP中,前置通知的执行顺序是在目标方法执行之前。 2. 环绕通知(Around Advice):环绕通知可以在目标方法执行前后都执行,它可以完全控制目标方法的执行过程。在AOP中,环绕通知的执行顺序是在目标方法执行之前和之后。 下面是一个示例代码,演示了如何使用AOP前置通知和环绕通知: ```python # 引入AOP库 from aop import Aspect, before, around # 定义一个切面类 class MyAspect(Aspect): # 前置通知 @before(target_method='my_method') def before_my_method(self, *args, **kwargs): print("执行前置通知") # 环绕通知 @around(target_method='my_method') def around_my_method(self, proceed, *args, **kwargs): print("执行环绕通知-前") result = proceed(*args, **kwargs) # 调用目标方法 print("执行环绕通知-后") return result # 定义一个目标类 class MyClass: def my_method(self): print("执行目标方法") # 创建切面对象 aspect = MyAspect() # 创建目标对象 target = MyClass() # 将切面织入目标对象 aspect.weave(target) # 调用目标方法 target.my_method() ``` 输出结果: ``` 执行前置通知 执行环绕通知-前 执行目标方法 执行环绕通知-后 ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

一剑封喉の

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

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

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

打赏作者

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

抵扣说明:

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

余额充值