spring--aop_2_源码分析之MethodInterceptor

本文深入分析了Spring AOP中MethodInterceptor的作用,以及如何通过AdvisorAdapterRegistry获取拦截器链。在代理对象调用目标方法时,DefaultAdvisorChainFactory结合DefaultAdvisorAdapterRegistry生成的拦截器链,实现了MethodInterceptor的匹配和调用,从而完成AOP功能。配置的advice通过ProxyFactoryBean解析成advisor链,并通过MethodMatcher进行匹配验证。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

前提:

https://blog.youkuaiyun.com/convict_eva/article/details/81084833

https://blog.youkuaiyun.com/convict_eva/article/details/81101432

前两篇分析了aop 两种方式实现的大致流程和方式,在这两种实现方式中都有一个很重要的方法获取拦截器链
List<Object> chain = this.advised.getInterceptorsAndDynamicInterceptionAdvice(method, targetClass);
所有的aop增强方法都封装在一个个拦截器中,然后根据这个拦截器链的调用进行增强。

此方法的实现是在advised 对象实现的(advised 是 AdvisedSupport 对象的实例,ProxyFactoryBean 是AdvisedSupport 子类)
 

public List<Object> getInterceptorsAndDynamicInterceptionAdvice(Method method, @Nullable Class<?> targetClass) {
	MethodCacheKey cacheKey = new MethodCacheKey(method);
	//这里使用了缓存来提高效率,第一次获取还是要创建的。
	//使用了 advisorChainFactory 生成拦截器链,advisorChainFactory 是 DefaultAdvisorChainFactory 的实例
	List<Object> cached = this.methodCache.get(cacheKey);
	if (cached == null) {
		cached = this.advisorChainFactory.getInterceptorsAndDynamicInterceptionAdvice(
				this, method, targetClass);
		this.methodCache.put(cacheKey, cached);
	}
	return cached;
}

advisorChainFactory.getInterceptorsAndDynamicInterceptionAdvice()源码:

@Override
public List<Object> getInte
### Spring 框架中的事务管理源码分析 #### 一、事务管理的核心组件 Spring 中的事务管理主要依赖于几个核心组件来实现。首先是 `PlatformTransactionManager` 接口,它是所有事务管理器都需实现的基础接口,在不同的持久化技术下有不同的具体实现类[^2]。 其次便是 `TransactionDefinition` 和 `TransactionStatus` 这两个接口,前者用于定义事务属性(如传播行为、隔离级别等),后者则表示当前事务的状态信息,包括是否新创建了一个事务以及该事务是否已标记为回滚只读状态等[^4]。 #### 二、声明式事务管理机制解析 对于声明式的事务处理而言,其背后的工作原理主要是借助AOP切面编程的思想来完成对业务方法执行过程中的环绕增强操作。当应用程序启动时会扫描带有 `@Transactional` 注解的方法并注册相应的代理对象,这些代理会在目标方法调用前后自动开启/提交或回滚数据库连接上的本地事务[^3]。 ```java // Transactional advice that wraps the target method invocation. public class TransactionInterceptor implements MethodInterceptor { private final PlatformTransactionManager transactionManager; private final TransactionAttributeSource transactionAttributeSource; @Override public Object invoke(MethodInvocation invocation) throws Throwable { // Determine current transaction attributes... TransactionInfo txInfo = createTransactionIfNecessary(...); try { Object retVal = invocation.proceed(); completeTransactionAfterReturning(txInfo); return retVal; } catch (Throwable ex) { completeTransactionAfterThrowing(txInfo, ex); throw ex; } finally { cleanupTransactionInfo(txInfo); } } } ``` 上述代码片段展示了 `TransactionInterceptor` 类的部分逻辑,它负责在每次被拦截的目标方法被执行之前先尝试根据配置好的规则决定是否需要新建一个事务实例,并将其绑定至线程局部变量以便后续访问;而在正常结束之后又可以依据同样的策略判断要不要把所做的更改同步回去给数据存储层[^5]。 #### 三、编程式事务管理简介 除了利用注释简化开发工作外,开发者也可以手动编写控制流语句来进行更细粒度的操作——即所谓的“编程式”。这种方式通常适用于那些无法简单映射成固定模式的任务场景里,比如跨多个资源库之间协调一致性的需求。此时就需要显式地获取到具体的 `PlatformTransactionManager` 实例并通过它的 API 来操纵整个生命周期内的各个阶段了。
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值