Spring AOP操作解析

首先需要使用@EnableAspectJAutoProxy注解,即为开启注解的aop模式
在这里插入图片描述
此注解导入了AspectJAutoProxyRegistrar类。

  1. 传入配置类,之后注册配置类,调用了refresh方法刷新容器
  2. 在registerBeanPostProcessors(beanFactory)方法中注册了后置处理器来方便拦截bean的创建过程。创建AnnotationAwareAspectJAutoProxyCreator对象。

AnnotationAwareAspectJAutoProxyCreator在每一个bean创建之前,
判断当前bean是否在advisedBeans中(保存了所有需要增强bean)
判断当前bean是否是基础类型的Advice、Pointcut、Advisor、AopInfrastructureBean,或者是否是切面(@Aspect)
判断是否需要跳过(获取候选的增强器(切面里面的通知方法【List candidateAdvisors】每一个封装的通知方法的增强器是 InstantiationModelAwarePointcutAdvisor;判断每一个增强器是否是 AspectJPointcutAdvisor 类型的;返回true
如果不是,返回false)
postProcessAfterInitialization如果需要的话,进行包装->
return wrapIfNecessary(bean, beanName, cacheKey);
如果当前bean需要增强,创建当前bean的代理对象;
1)、获取所有增强器(通知方法)
2)、保存到proxyFactory
3)、创建代理对象:Spring自动决定 JdkDynamicAopProxy(config);jdk动态代理或ObjenesisCglibAopProxy(config);cglib的动态代理;
生成代理之后给容器返回代理对象。执行目标方法的时候获取的就是代理对象。

目标方法执行的时候
CglibAopProxy.intercept();拦截目标方法的执行
根据ProxyFactory对象获取将要执行的目标方法拦截器链;
List chain = this.advised.getInterceptorsAndDynamicInterceptionAdvice(method, targetClass);
1)、List interceptorList保存所有拦截器 5
一个默认的ExposeInvocationInterceptor 和 4个增强器;
2)、遍历所有的增强器,将其转为Interceptor;
registry.getInterceptors(advisor);
3)、将增强器转为List;
如果是MethodInterceptor,直接加入到集合中
如果不是,使用AdvisorAdapter将增强器转为MethodInterceptor;
转换完成返回MethodInterceptor数组;
如果拦截器为空,直接执行目标方法即可,如果不为空把需要执行的目标对象,目标方法,拦截器链等信息传入创建一个 CglibMethodInvocation 对象,并调用 Object retVal = mi.proceed();
链式获取每一个拦截器,拦截器执行invoke方法,每一个拦截器等待下一个拦截器执行完成返回以后再来执行;拦截器链的机制,保证通知方法与目标方法的执行顺序;
正常执行:前置通知-》目标方法-》后置通知-》返回通知
出现异常:前置通知-》目标方法-》后置通知-》异常通知
红色标号即为顺序

具体执行方法如图所示。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值