OOP弊端当需要多个不具有继承关系的关系的对象引入一个公共行为时,会比较麻烦
对于一个公共模块的调用,除了直接调用没有好的方法
所以引入面向方面编程
底层实现技术:java代理,程序预编译,拦截器框架、类装载器框架、元数据处理
上层:基础 切面 类型检查 优化,配置模型、高层api
比如单独引入AspectJ 需要使用AspectJ语言和编辑器
低版本的Spring 实现特定接口和一些复杂的配置
在Spring 2.0 引入@AspectJ方便定义一个切面。
Spring2.0将切面织入到匹配的Bean中
AspectJ切点语法进行切点定义,可以通过切点函数 运算符 通配符 切点定义拥有强大的连接点描述能力。
动态aop的使用
1 满足业务需要的核心逻辑
创建用于拦截的bean
2.创建Advisor 可以使用@AspectJ @Pointcut @Before @ after @around(p.procedd)
3.创建配置文件 在xml中开启AOP
aop:aspectj-autoproxy
作用是增强Bean 辅助功能独立于核心业务
那么Spring 如何实现AOP???
分析aop:aspectj-autoproxy
如果声明了注解肯定有注册对应的解析器
注册是在AopNamespaceHandler中的init()注册
public class AopNamespaceHandler extends NamespaceHandlerSupport {
/**
* Register the {@link BeanDefinitionParser BeanDefinitionParsers} for the
* '{@code config}', '{@code spring-configured}', '{@code aspectj-autoproxy}'
* and '{@code scoped-proxy}' tags.
*/
@Override
public void init() {
// In 2.0 XSD as well as in 2.1 XSD.
registerBeanDefinitionParser("config", new ConfigBeanDefinitionParser());
registerBeanDefinitionParser("aspectj-autoproxy", new AspectJAutoProxyBeanDefinitionParser());
registerBeanDefinitionDecorator("scoped-proxy", new ScopedProxyBeanDefinitionDecorator());
// Only in 2.0 XSD: moved to context namespace as of 2.1
registerBeanDefinitionParser("spring-configured", new SpringConfiguredBeanDefinitionParser());
}
}
间接继承自NamespaceHandler 3个方法init parse decorate
发现它注册了配置 aop 代理作用域 spring配置
直接继承类NamespaceHandler 对parse和decorate提供了实现 并有注册解析的方法
Spring中自定义注解的方式
解析器是AspectJAutoProxyBeanDefinitionParser
接下来深入分析该类
BeforeAdvice会有一个方法before的实现会在配置到目标方法后,调用方法前执行