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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值