spring-AOP1

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/Justnow_/article/details/52458206

spring-AOP

本文主要参考自以下两篇英文文档:
http://http://www.tutorialspoint.com/spring/spring_bean_life_cycle.htm
http://docs.spring.io/spring/docs/current/spring-framework-reference/html/aop.html


对于spring框架而言,其中一个重要的组成部分便是-Aspect oriented programming (AOP) 。面向切面编程将代码以业务代码和关注点代码区分开来。它有效地解决了分散在各个组件里的关注点代码难以管理,并且无限重复和拖沓的痛点。比较典型的应用场景包括,日志记录,类型检查,声明式事务管理,安全管理,以及缓存服务等。


我们知道,面向对象编程(OOP)的核心思想在于类(class)的定义和创建,而AOP的核心思想在于切面(aspect)。spring框架的依赖注入(DI)使得你的应用程序对象之间相互解耦,而AOP的出现,使得你的关注点代码与核心业务代码之间解耦。


spring的AOP模块提供了拦截器类,用于拦截应用服务。譬如,当一个方法被执行的时候,你可以在这个方法执行前或者执行后添加相应你想要的功能

AOP相关术语

在开始学习AOP之前,我们可以先熟悉一下相关的AOP概念以及相关术语。

术语 含义
Aspect 切面,通常指的是拦截目标对象,并在目标对象方法执行前后添加相应操作的类
Join point 指的是切面类执行相应操作的切入点,可以想象成应用程序中将会被应用AOP的一个点
Advice 执行切入操作时的通知,是前置(before),后置(after),或者环绕通知?这个会在应用aop时触发
Pointcut 由一个或者多个切入点构成,决定了其通知什么时候被执行。我们可以为它指定切入点表达式
Introduction 可以让你为目标对象添加新的方法和属性
Target object 应用了一个或者多个切面的对象,这个对象通常是代理对象,也可以指定通知的对象
Weaving 织入-指在编译,加载,运行时进行切入操作的动作

通知的类型

springAOP的advice通常由以下五种组成:

Advice Description
before 在目标方法执行前触发
after 在目标对象方法执行完毕后触发,不论该方法是正常返回还是抛出异常,均会执行。类似于try catch finally中的finally
after-returning 方法成功执行并返回时触发
after-throwing 方法执行抛出异常时触发
around 环绕通知–在方法执行前和执行后均会触发

springAOP的实现方式

spring支持两种类型的aop实现,一种是基于XML配置,另一种是基于AspectJ的配置

  • 基于XML的配置

操作步骤

  • 创建一个普通java类(用作切面)

    public class XmlAspectDemo {
    private static final Logger LOGGER = LoggerFactory.getLogger(XmlAspectDemo.class);

    /**

    • 方法执行前执行
      */
      public void doBefore() {
      LOGGER.info(“do before the method”);

    }

    public void doAfter() {

    LOGGER.info(“do after the method”);
    }

    public void doAround(ProceedingJoinPoint joinPoint) throws Throwable {
    LOGGER.info(“this is Around method , do before”);
    LOGGER.info(“method is proceeding”);
    joinPoint.proceed();
    LOGGER.info(“method has been executed ,do after”);
    }
    }

    1. 创建一个需要被aop处理的TargetAopDemo类

    ` public class TargetAopDemo {

    private static final Logger LOGGER = LoggerFactory.getLogger(TargetAopDemo.class);

    public void write(){
    LOGGER.info(“target class’s method has executed!”);
    }
    } `

  • 在xml中注册bean


  • 在xml中配置aop








  • 运行目标对象的write方法时即可发现该方法执行时被代理了

猜你喜欢

转载自blog.csdn.net/Justnow_/article/details/52458206