Spring框架基础入门2:AOP--面向切面编程

Spring框架基础入门2:AOP--面向切面编程,第1张

什么是AOP

AOP为Aspect Oriented Programming的缩写,意为:面向切面编程

利用AOP可以对业务逻辑的各个部分进行隔离,从而使得业务逻辑各部分之间的耦合度降低,提高程序的可重用性,同时提高了开发的效率。

AOP的优势

1. 减少重复的代码

2. 提供开发的效率

3. 维护方便

AOP的底层原理

JDK的动态代理技术

1、为接口创建代理类的字节码文件

2、使用ClassLoader将字节码文件加载到JVM

3、创建代理类实例对象,执行对象的目标方法

cglib代理技术

为类生成代理对象,被代理类有没有接口都无所谓,底层是生成子类,继承被代理类。

AOP相关的术语

Joinpoint(连接点) 类里面有哪些方法可以增强这些方法称为连接点,理论上所有方法都可作为连接点。

Pointcut(切入点) -- 被增强的连接点就是切入点,可以是一个也可以是多个。

Advice(通知/增强)--我们要添加到切入点的方法就是增强(通知)。通知分为

前置通知:在切入点之前增强

后置通知:在切入点之后增强

环绕通知:在切入点之前和之后都增强

异常通知:切入点异常时增强(切入点正常运行就不增强)

最终通知:无论切入点成功与否都增强

Aspect(切面)-- 是 切入点+通知 的结合,我们可以理解为一个过程:将通知应用到切入点

实际 *** 作

新建一个maven项目并导入相关依赖,和之前的IOC相同,这里不再赘述


    
        org.springframework
        spring-context
        5.0.2.RELEASE
    
    
        commons-logging
        commons-logging
        1.2
    
    
        org.springframework
        spring-test
        5.0.2.RELEASE
    
    
        log4j
        log4j
        1.2.12
    
    
        junit
        junit
        4.12
        test
    
    
    
        aopalliance
        aopalliance
        1.0
    
    
    
        org.springframework
        spring-aspects
        5.0.2.RELEASE
    
    
    
        org.aspectj
        aspectjweaver
        1.8.3
    

我们先来定义一个User类

public class User {

    public void add(){
        System.out.println("add-----");
    }

    public void select(){
        System.out.println("select------");
    }

    public void delete(){
        System.out.println("delete-------");
    }

    public void update(){
        System.out.println("update--------");
    }

然后再定义一个UserProxy类:增强类(切入类)

我们通过xml配置的方式先来实现前置通知。

首先利用IOC生成User对象


然后定义切面类


准备工作完成,接下来配置切面以实现前置通知


    
        
        
            
            
            
        
    

我们来测试一下

    @Test
    public void run(){
        ApplicationContext ac = new ClassPathXmlApplicationContext("applicationContext.xml");
        User user = (User) ac.getBean("user");
        user.add();
    }

接下来实现环绕通知

首先定义环绕通知 

public void around(ProceedingJoinPoint proceedingJoinPoint) throws Throwable {
        System.out.println("环绕前");
        proceedingJoinPoint.proceed();
        System.out.println("环绕后");
    }

然后在xml文档中配置环绕通知,和前置通知基本一致


    
        
        
            
                    
        
            
        
    

测试结果

 后置通知:

 

最终通知:无论切入点是否报错,最终通知都会运行。

 

异常通知:只有在切入点报错时才会执行

接下来介绍注解的方式实现通知增强

首先还是在xml文档中进行总体配置

        
        

        
        

然后为User类UserProxy类添加@Component

我们需要在UserProxy类添加额外注解:@Aspect   以此来表示当前类为增强类

然后将before方法定义为前置通知

@Before(value = "execution(public void com.qcby.User.add())")
    public void before(){
        System.out.println("前置通知实现");
    }

 测试结果:

后置通知

@AfterReturning(value = "execution(public void com.qcby.User.add())") 

最终通知

@After(value = "execution(public void com.qcby.User.add())")  //最终通知

异常通知 

@AfterThrowing(value = "execution(public void com.qcby.User.add())")  //异常通知

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/798942.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-06
下一篇 2022-05-06

发表评论

登录后才能评论

评论列表(0条)

保存