SpringAOP(1)-spring源码详解(六)

上篇文章说了spring监听器,监听event,先把事件全部存储在多播器,通过publicEvent来触发多播器发送事件,他可以通过代码注解,或者实现接口的方式来实现事件监听,达到解耦和异步的效果。

Spring监听器-spring源码详解(五)icon-default.png?t=M85Bhttps://blog.csdn.net/ke1ying/article/details/127780075

Aop要实现的是在我们原来的代码基础上进行一些包装,比如在方法执行前,方法抛出异常之后进行拦截处理,又叫增强处理。与前面ioc的一些后置处理器构造方法不同,aop主要是动态代理来实现的。

SpringAop是基于动态代理,当使用接口的时候是jdk动态代理实现,不是则是用cglib来实现。(cglb是通过asm开源框架动态修改底层字节码,修改需要被增强的.class)

Spring主要用到aspect切点解析,注解。

除了上面的@aspct来增强外,还可以通过实现interceptor的方式来做一些增强。

@Aspect,@Before,@after

拿到所有bean定义,是不是标记了@aspect,每个通知都会生成一个advisor。里面有advise

和pointcut。

那倒是所有advisors之后,pointcut然后matches创建动态proxy。

SpringAOP(1)-spring源码详解(六)_第1张图片

 SpringAOP(1)-spring源码详解(六)_第2张图片

通过@EnableAspectJAutoProxy可以注册一个bean定义。

解析切面的第一步就是在postProcessorBeforeInstiation里。

 SpringAOP(1)-spring源码详解(六)_第3张图片

 SpringAOP(1)-spring源码详解(六)_第4张图片

SpringAOP(1)-spring源码详解(六)_第5张图片 

SpringAOP(1)-spring源码详解(六)_第6张图片 

创建动态代理AbstractAutoProxyCreator里的后置处理器。

判断是否直接跳过,跳过的规则是,判断是不是切面类,通知类,切点类,advice,pointcut,advisor等,如果是,则返回true。

当findCandidateAdvisors找不到的时候,会调用buildAspectJAdvisors方法解析所有的切面。SpringAOP(1)-spring源码详解(六)_第7张图片

在这里会循环Object的bean定义,也就是拿到所有beanName,判断是不是aspect切面。

主要通过判断findAnnotation 是否标记aspect注解。

SpringAOP(1)-spring源码详解(六)_第8张图片

这里有个回调钩子方法,会把pointCut注解的忽略掉,没有则加到methods里面去。

这里会有一个sort排序,为什么排序呢,因为后面会根据责任链调用。

Around,before,after,afterReturning,afterTrowing。

 

你可能感兴趣的:(后端,spring,java)