Spring - AOP简介与图示

【1】AOP

(Aspect-Oriented Programming, 面向切面编程),是一种新的方法论, 是对传统 OOP(Object-Oriented Programming, 面向对象编程) 的补充.java

AOP 的主要编程对象是切面(aspect), 而切面模块化横切关注点.web

在应用 AOP 编程时, 仍然须要定义公共功能, 但能够明确的定义这个功能在哪里, 以什么方式应用, 而且没必要修改受影响的类. 这样一来横切关注点就被模块化到特殊的对象(切面)里.spring

这里要说明下,因为Spring AOP是使用JDK动态代理和CGLIB代理实现的,所以Spring AOP只能够对方法的执行进行拦截,若是须要拦截字段的访问或更新,则须要像AspectJ这样的AOP语言。数据库

另外Spring能够无缝的集成IOC,Spring AOP 以及AspectJ AOP。编程


【2】AOP术语

将多处地方具备相似功能的代码(横切关注点)抽取出来,进行模块化为一个方法(通知-Advice);bash

将同一事务的不一样方法(如前置通知、后置通知)放在一个类中(即,切面–Aspect);markdown

在方法上利用Aspect表达式定义切点,当有匹配其表达式的目标对象方法执行时,会自动为其创建代理对象-Proxy;模块化

切面(Aspect): 横切关注点(跨越应用程序多个模块的功能)被模块化的特殊对象--类级别 通知(Advice): 切面必需要完成的工做--即方法(方法级别) 目标(Target): 被通知的对象 代理(Proxy): 向目标对象应用通知以后建立的对象

链接点(Joinpoint):post

程序执行的某个特定位置。flex

如类某个方法调用前、调用后、方法抛出异常后等。


链接点由两个信息肯定:

方法(表示程序执行点,即-在哪一个目标方法);

相对点(表示方位,即-目标方法的什么位置,如调用前、后。。。)


例如 :ArithmethicCalculator#add()方法执行前的链接点:

方法为ArithmethicCalculator#add(); 相对点为该方法执行前的位置

切入点(pointcut):

AOP 经过切点定位到特定的链接点。

经过某种定义来决定哪些方法将会被通知(即须要事物处理),咱们将这个定义秤为切入点(Pointcut),而每个被处理的方法咱们称之为链接点(Join Point)。

每一个类都拥有多个链接点。例如 ArithmethicCalculator 的全部方法实际上都是链接点,即链接点是程序类中客观存在的事务。

类比:链接点至关于数据库中的记录,切点至关于查询条件。

切点和链接点不是一对一的关系,一个切点经常匹配多个链接点.

切点经过 org.springframework.aop.Pointcut 接口进行描述,它使用类和方法做为链接点的查询条件。


【3】AOP图示

这里写图片描述


【4】AOP简单实例

package com.web.aop.impl; import java.util.Arrays; import java.util.List; import org.aspectj.lang.JoinPoint; import org.aspectj.lang.annotation.After; import org.aspectj.lang.annotation.Aspect; import org.aspectj.lang.annotation.Before; import org.springframework.stereotype.Component; /* @Component表示将其放入IOC容器中,使其能够被自动扫描; @Aspect表示其为一个切面 */ @Aspect @Component public class LoggingAspect { @Before("execution(int com.web.aop.impl.ArithmeticCalculatorImpl.*(int , int ))") public void beforMethod(JoinPoint joinPoint){ /*获取方法名*/ String methodName = joinPoint.getSignature().getName(); /*获取方法的参数*/ List<Object> args = Arrays.asList(joinPoint.getArgs()); System.out.println("The method"+methodName+" begins with"+args); } /* * 后置通知:在目标方法执行后执行,不管是否抛出异常; * 后置通知中不能访问目标方法执行后返回的结果; * */ @After("execution(* com.web.aop.impl.*.*(int , int ))") /*表示该包下全部返回类型的全部类的全部方法*/ public void afterMethod(JoinPoint joinPoint){ /*获取方法名*/ String methodName = joinPoint.getSignature().getName(); System.out.println("The method"+methodName+" ends "); } }

扫码向博主提问

去开通个人Chat快问

j080624

非学,无以至疑;非问,无以广识
  • 擅长领域:
  • Java
  • 数据库
  • Linux
  • HTML5
相关文章
相关标签/搜索