SpringAop

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的实现会在配置到目标方法后,调用方法前执行

你可能感兴趣的:(SpringAop)