Spring中AOP源码剖析
一、环境准备
1 bean和接口
public class AopBean implements AopBeanInfo{
@Override
public void test() {
System.out.println("spring aop test... ...");
}
}
public interface AopBeanInfo {
public void test();
}
2 横切逻辑
public class LogUtils {
public void beforeMethod() {
System.out.println("前置通知");
}
public void alertMethod(){
System.out.println("最终通知");
}
public Object aroundMethod(ProceedingJoinPoint pjp) throws Throwable{
System.out.println("环绕通知-pre");
Object proceed = pjp.proceed();
System.out.println("环绕通知-after");
return proceed;
}
public void afterThrowingMethod(){
System.out.println("异常通知");
}
public void afterReturning(){
System.out.println("后置通知");
}
}
3 配置文件:
<?xml version="1.0" encoding="UTF-8"?>
<beans xmlns="http://www.springframework.org/schema/beans"
xmlns:aop="http://www.springframework.org/schema/aop"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="
http://www.springframework.org/schema/beans
https://www.springframework.org/schema/beans/spring-beans.xsd
http://www.springframework.org/schema/aop
https://www.springframework.org/schema/aop/spring-aop.xsd
">
<bean id="aopBean" class="com.dabing.source.aop.AopBean"></bean>
<bean id="logUtils" class="com.dabing.source.aop.LogUtils"></bean>
<aop:config>
<aop:aspect ref="logUtils">
<aop:before method="beforeMethod" pointcut="execution(public void com.dabing.source.aop.AopBean.test())"/>
<aop:after method="alertMethod" pointcut="execution(public void com.dabing.source.aop.AopBean.test())"/>
<aop:around method="aroundMethod" pointcut="execution(public void com.dabing.source.aop.AopBean.test())"/>
<aop:after-returning method="afterReturning" pointcut="execution(public void com.dabing.source.aop.AopBean.test())"/>
<aop:after-throwing method="afterThrowingMethod" pointcut="execution(public void com.dabing.source.aop.AopBean.test())"/>
</aop:aspect>
</aop:config>
</beans>
4 测试类:
@Test
public void testAop(){
ApplicationContext applicationContext = new ClassPathXmlApplicationContext("classpath:applicationContext-aop.xml");
AopBeanInfo aopBean = applicationContext.getBean(AopBeanInfo.class);
aopBean.test();
}
5 测试结果:
data:image/s3,"s3://crabby-images/3f70e/3f70ecfd36f7a2ccafeed7bf03e6ec5a17b7b95e" alt="在这里插入图片描述"
二、源码剖析
data:image/s3,"s3://crabby-images/fab52/fab52acc8bb6760ff8862a22c9714754b1262f13" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/64169/64169da9e692b3027d264ea1ad26f243495478e8" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/0d998/0d998a3f9478edd01e718fd80414bbe67993919e" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/0b7dc/0b7dc4f4f9d87d9dcf847fefaacb3370945738a5" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/58a0c/58a0c902c8820877cf733bcbd5cc70d76499fea6" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/26712/267124f3ac5e2bef2d1671cca64fcec0932bcb5c" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/0d61f/0d61f01d366d59e63dc5f1f3d8bf2c1375cf1e9a" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/8ec3d/8ec3dfdf6adf6b469a21883736141dcac3185d30" alt="在这里插入图片描述" 设置断点条件 data:image/s3,"s3://crabby-images/23708/2370886aa8339c0dc1779ac9dda550f8b8eece48" alt="在这里插入图片描述" 放行 data:image/s3,"s3://crabby-images/5435d/5435d5dafdaadb48af474d35f2bd56d19d107ce4" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/fa7ac/fa7aceff43824cd99624c1b7e2ad3736cdef1d48" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/c7ab9/c7ab920863681961bcc7127cdc1fcc47fc3ed504" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/64ef9/64ef9c3128e7fcaae97d3b7c1c7aa4c77e981287" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/4133e/4133ed7fb7b1987aebd484cd283bfc593f7ef174" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/308c3/308c39c20e4df07dee95e700883e1b83ae605344" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/b52f0/b52f0a78cb26d1286072da073b1b30c5825d0c03" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/0696c/0696c4229e342fe054bf5c833c20346d0b42ac8e" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/6b674/6b67420a4cb2628c2cb84f022a2f613e51a6c7d8" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/1e8c9/1e8c9b516c7b1d049fc053327a614b856802c6eb" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/98c72/98c7237f5431cf1ddf2f5ed130c5e004f4d3ff16" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/d2253/d2253fddaedb3e61821a923ea4d9706c45f568dd" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/0cb74/0cb741aee2bf7f7b73bb36bafc4b5dd47e73200f" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/8ac66/8ac66a4ea93441b51fd4297cfa9cbdf02ccd1d6b" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/9f9e2/9f9e254fd5c51f0a771b0587c0f17b4fdae46b5f" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/eb30c/eb30c87bfae0980618bf2020a0bfd2a25271403f" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/9c5bd/9c5bd2f99b72306ac2eb21ece23dc7dcb9a5969c" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/ef94b/ef94b6b6ea2cc98b4947eff23ee821d37ccccaae" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/a29d6/a29d63ac16b5cd602d32af4222dbd22a54d676ec" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/2e6f6/2e6f615aaaaaa6cfe55d28310f2001c79e749ef7" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/d8e20/d8e20159764d7d93e03e6093631e1d041ddc2b25" alt="在这里插入图片描述"
递归1-into: data:image/s3,"s3://crabby-images/2a1dc/2a1dc835fe3233679b07eb6f043aef925e4c6b74" alt="在这里插入图片描述" 此处进行了递归调用:在proceed方法中继续调用proceed方法 data:image/s3,"s3://crabby-images/a4178/a4178f0ff787b2d84ad1b0af0c02f481f737fcb0" alt="在这里插入图片描述"
递归2-into:
data:image/s3,"s3://crabby-images/a2051/a20515ee7cb89bd649a98939e3f1d3f0c37f57d4" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/5e1fa/5e1fadc47c7c91572c800f8522a9290e62ec06c3" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/0127a/0127a3d972fb6e63730aab14868a05c138b7f260" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/b4842/b4842641a5c230092d3aeccda687666bb746d715" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/ca634/ca634a5aec4f2b40a5e0c4a4ac07c606a15598e4" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/66807/66807bcfa3572ecdf52ea61fbdcbdf95516c6aa0" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/c79f4/c79f4035f050d4da3b5c17a677fea453776375a5" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/109a1/109a1b5088640a985b552171ff732f49ec13b527" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/311e5/311e52d096090c15f057030fbc17a26c8253447d" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/f515c/f515c1f7c22da79df19ec6b29234322ff8667905" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/16558/1655858ab859640323239c32f59788e34075b3ea" alt="在这里插入图片描述" 递归3-into: data:image/s3,"s3://crabby-images/aa508/aa508d143890014836b75054adbfd33fecba2d0c" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/2bec4/2bec40e16492f5d470e2e4551fc1a44eff042ea3" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/422e6/422e6818ddd57fd0ea042e91150d3b333506a4e2" alt="在这里插入图片描述"
总结
- aop的增强发生在后置处理器中(没有循环依赖)
- 最终增强是通过递归调用,层层增强
|