3.0一、Spring AOP的理解

注:转    https://mp.weixin.qq.com/s/PsgTLn8cdTxdd542XgVkUAexpress

什么是AOP

AOP(Aspect-Oriented Programming), 即 面向切面编程 , 它与 OOP( Object-Oriented Programming, 面向对象编程) 相辅相成, 提供了与 OOP 不一样的抽象软件结构的视角. 
在 OOP 中, 咱们以类(class)做为咱们的基本单元, 而 AOP 中的基本单元是 Aspect(切面)

一、Aspect(切面)

Aspect 由 pointcount 和 advice 组成, 它既包含了横切逻辑的定义, 也包括了链接点的定义. Spring AOP就是负责实施切面的框架, 它将切面所定义的横切逻辑织入到切面所指定的链接点中. AOP的工做重心在于如何将加强织入目标对象的链接点上, 这里包含两个工做:编程

1. 如何经过 pointcut 和 advice 定位到特定的 joinpoint 上app

2. 如何在 advice 中编写切面代码.框架

能够简单地认为, 使用 @Aspect 注解的类就是切面.spa

二、Advice(加强)

由 aspect 添加到特定的 join point(即知足 point cut 规则的 join point) 的一段代码. 许多 AOP框架, 包括 Spring AOP, 会将 advice 模拟为一个拦截器(interceptor), 而且在 join point 上维护多个 advice, 进行层层拦截. 例如 HTTP 鉴权的实现, 咱们能够为每一个使用 RequestMapping 标注的方法织入 advice, 当 HTTP 请求到来时, 首先进入到 advice 代码中, 在这里咱们能够分析这个 HTTP 请求是否有相应的权限, 若是有, 则执行 Controller, 若是没有, 则抛出异常. 这里的 advice 就扮演着鉴权拦截器的角色了..net

advice的类型:代理

    1) before advice, 在 join point 前被执行的 advice. 虽然 before advice 是在 join point 前被执行, 可是它并不可以阻止 join point 的执行,
           除非发生了异常(即咱们在 before advice 代码中, 不能人为地决定是否继续执行 join point 中的代码)对象

    2)after return advice, 在一个 join point 正常返回后执行的 advice接口

    3)after throwing advice, 当一个 join point 抛出异常后执行的 adviceget

    4)after(final) advice, 不管一个 join point 是正常退出仍是发生了异常, 都会被执行的 advice

    5)around advice, 在 join point 前和 joint point 退出后都执行的 advice. 这个是最经常使用的 advice

三、Join Point(链接点)

程序运行中的一些时间点, 例如一个方法的执行, 或者是一个异常的处理.在 Spring AOP 中, join point 老是方法的执行点, 即全部方法的执行点

四、Point Cut(切点)

匹配 join point 的谓词Advice 是和特定的 point cut 关联的, 而且在 point cut 相匹配的 join point 中执行.在 Spring 中, 全部的方法均可以认为是 join point, 可是咱们并不但愿在全部的方法上都添加 Advice, 而 point cut 的做用就是提供一组规则(使用 AspectJ pointcut expression language 来描述) 来匹配join point, 给知足规则的 join point 添加 Advice.

关于join point 和 point cut 的区别:

在 Spring AOP 中, 全部的方法执行都是 join point。 而 point cut 是一个描述信息, 它修饰的是 join point, 经过 point cut, 咱们就能够肯定哪些 join point 能够被织入 Advice. 所以 join point 和 point cut 本质上就是两个不一样纬度上的东西.advice 是在 join point 上执行的, 而 point cut 规定了哪些 join point 能够执行哪些 advice

五、 Target (目标对象)

织入 advice 的目标对象. 目标对象也被称为 advised object.由于 Spring AOP 使用运行时代理的方式来实现 aspect, 所以 adviced object 老是一个代理对象(proxied object)注意, adviced object 指的不是原来的类, 而是织入 advice 后所产生的代理类

六、Aop proxy(aop  代理)

一个类被 AOP 织入 advice, 就会产生一个结果类, 它是融合了原类和加强逻辑的代理类. 在 Spring AOP 中, 一个 AOP 代理是一个 JDK 动态代理对象或 CGLIB 代理对象

关于 AOP Proxy

Spring AOP 默认使用标准的 JDK 动态代理(dynamic proxy)技术来实现 AOP 代理, 经过它, 咱们能够为任意的接口实现代理。
若是须要为一个类实现代理, 那么可使用 CGLIB 代理. 当一个业务逻辑对象没有实现接口时, 那么Spring AOP 就默认使用
CGLIB 来做为AOP代理了。 即若是咱们须要为一个方法织入 advice, 可是这个方法不是一个接口所提供的方法,
则此时 Spring AOP 会使用 CGLIB 来实现动态代理。 鉴于此, Spring AOP 建议基于接口编程, 对接口进行 AOP 而不是类。

七、Weaving(织入)

将 aspect 和其余对象链接起来, 并建立 adviced object 的过程. 根据不一样的实现技术, AOP织入有三种方式

    1) 编译器织入, 这要求有特殊的Java编译器

    2) 类装载期织入, 这须要有特殊的类装载器

    3) 动态代理织入, 在运行期为目标类添加加强(Advice)生成子类的方式. Spring 采用动态代理织入, 而AspectJ采用编译器织入和类装载期织入

 

举例:

    比喻一下 AOP 中 aspect, jointpoint, pointcut 与 advice 之间的关系.

    让咱们来假设一下, 从前有一个叫爪哇的小县城, 在一个月黑风高的晚上, 这个县城中发生了命案. 做案的凶手十分狡猾, 现场没有留下什么有价值的线索。
不过万幸的是, 刚从隔壁回来的老王刚好在这时候无心中发现了凶手行凶的过程, 可是因为天色已晚, 加上凶手蒙着面, 老王并无看清凶手的面目, 只知道
凶手是个男性, 身高约七尺五寸。爪哇县的县令根据老王的描述, 对守门的士兵下命令说: 凡是发现有身高七尺五寸的男性, 都要抓过来审问。士兵固然不敢
违背县令的命令, 只好把进出城的全部符合条件的人都抓了起来。

    来让咱们看一下上面的一个小故事和 AOP 到底有什么对应关系。 首先咱们知道, 在 Spring AOP 中 join point 指代的是全部方法的执行点,
而 point cut 是一个描述信息, 它修饰的是 join point, 经过 point cut, 咱们就能够肯定哪些 join point 能够被织入 Advice。 对应到咱们在上面
举的例子, 咱们能够作一个简单的类比, join point 就至关于爪哇的小县城里的百姓 , point cut 就至关于 老王所作的指控, 即凶手是个男性, 身高约
七尺五寸 , 而 advice 则是施加在符合老王所描述的嫌疑人的动做: 抓过来审问 . 为何能够这样类比呢?

join point --> 爪哇的小县城里的百姓: 由于根据定义, join point 是全部可能被织入 advice 的候选的点, 在 Spring AOP中, 则能够认为全部方法执行点都是 join point。
               而在咱们上面的例子中, 命案发生在小县城中, 按理说在此县城中的全部人都有多是嫌疑人。
point cut  --> 男性, 身高约七尺五寸: 咱们知道, 全部的方法(joint point) 均可以织入 advice, 可是咱们并不但愿在全部方法上都织入 advice, 而 pointcut 的做用就是提供一组
               规则来匹配joinpoint, 给知足规则的 joinpoint 添加 advice. 同理, 对于县令来讲, 他再昏庸, 也知道不能把县城中的全部百姓都抓起来审问, 而是根据凶手是个男性,
               身高约七尺五寸, 把符合条件的人抓起来. 在这里 凶手是个男性, 身高约七尺五寸 就是一个修饰谓语, 它限定了凶手的范围, 知足此修饰规则的百姓都是嫌疑人, 都须要
               抓起来审问。
advice     --> 抓过来审问, advice 是一个动做, 即一段 Java 代码, 这段 Java 代码是做用于 point cut 所限定的那些 join point 上的. 同理, 对比到咱们的例子中, 抓过来审问
               这个动做就是对做用于那些知足 男性, 身高约七尺五寸 的爪哇的小县城里的百姓.
aspect    :    aspect 是 point cut 与 advice 的组合, 所以在这里咱们就能够类比: "根据老王的线索, 凡是发现有身高七尺五寸的男性, 都要抓过来审问" 这一整个动做能够被认为
               是一个aspect.
相关文章
相关标签/搜索