Spring AOP
AOP 介绍
AOP(Aspect Orient Programming),面向切面编程的意思。它是一种思想,是面向对象编程(OOP:Object Oriented Programming)的一种补充。面向对象编程将程序抽象成各个层次的对象,而面向切面编程是将程序抽象成各个切面。
在程序开发中主要用来解决一些系统层面的问题,比如日志、事务、权限等,Struts2的拦截器设计就是基于AOP的思想。
在不改变原有逻辑的基础上,增加一些额外的功能。代理也是这个功能,读写分离也能用AOP来做。
切面实现了横切关注点(跨多个应用对象的逻辑)的模块化。
比如:
上图就形象的表示了何为切面,其实就是相当于应用对象间的横切点,可以将其单独抽象为单独的模块。
AOP相关概念
- 横切关注点
对那些方法进行拦截,拦截后怎么处理,这些关注点被称为横切关注点。 - Aspect(切面)
通常是一个类,里面可以定义切入点和通知。 - JointPoint(连接点)
程序执行过程中明确的点,一般是方法的调用。被拦截到的点,因为spring只支持方法类型的连接点,所以在spring中连接点指的是被拦截到的方法,实际上连接点还可以是字段或者构造器。 - Advice(通知)
AOP在特定切入点上执行的增强处理,有before(前置)、after(后置)、after’Returning(最终)、afterThrowing(异常)、around(环绕)。 - PointCut(切入点)
就是带有通知的连接点,在程序中主要体现为书写切入点表达式。 - weave(织入)
将切面应用到目标对象并导致代理对象创建的过程。 - introduction(引入)
在不修改代码的前提下,引入可以在运行期为类动态地添加一些方法和字段。 - AOP代理(AOP proxy)
AOP框架创建的对象,代理就是目标对象地加强。spring中地AOP代理可以是jdk动态代理,也可以是cglib代理,前者基于接口,后者基于子类。 - 目标对象
包含连接点的对象。也叫被通知对象或者被代理对象。
Advice通知的类型
- before(前置)
在目标方法被调用之前做增强处理。
@Before只需要指定切入点表达式即可。 - afterReturning(最终)
在目标方法正常结束后做增强处理。
@AfterReturning吃了指定切入点表达式,还可以指定一个返回值形参,代表目标方法的返回值。 - afterthrowing(异常)
主要用来处理程序中未处理的异常。
@AfterThrowing除了指定切入点表达式,还可以指定一个throwing的返回值形参,可以通过该形参来访问目标方法中所抛出的异常对象。 - after(后置)
在目标方法完成之后做增强。
@After可以指定一个切入点表达式。 - around(环绕)
环绕通知在目标方法完成前后做增强处理,环绕通知是最重要的通知类型,像事务、日志等都是环绕通知。
AOP的使用场景
- Authentication(权限)
- Caching(缓存)
- Context passing(内容传递)
- Error handling(错误处理)
- lazy loading(懒加载)
- Debugging(调试)
- logging, tracing, profiling and monitoring(记录跟踪 优化 校准)
- Performance optimization(性能优化)
- Persistence(持久化)
- Resource pooling(资源池)
- Synchronization(同步)
- Transactions (事务)
- journal(日志)
为什么要用AOP
在不改变程序代码的情况下,为系统中的业务组件添加某种通用功能。
传统面向过程编程中,多模块共用某段重复代码的话,会将这段代码抽象成一个方法,在需要的地方进行调用,这样修改起来就只改这一个方法就行了。但是如果是多个地方进行不同修改的话,就必须要抽象出多个方法进行相应的调用了,这样后期的维护成本比较大。
实际上涉及到多个地方具有相同修改的问题就可以用AOP来解决。
AOP的底层实现
详情点击 Spring AOP的底层实现是怎样的?