Spring中基于XML的AOP配置详解

时间:2021-05-20

1. 准备工作

1.1 创建工程 day03_eesy_03SpringAOP

1.2 在配置文件pom.xml中添加依赖

<?xml version="1.0" encoding="UTF-8"?><project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://.itheima.service.impl.AccountServiceImpl.*(..))"></aop:pointcut> <!--配置切面--> <aop:aspect id="logAdvice" ref="logger"> <!--配置环绕通知 详细的注释在Logger类中--> <aop:around method="aroundPringLog" pointcut-ref="pt1"></aop:around> </aop:aspect> </aop:config></beans>

9.3 此时运行结果

9.4 问题分析

此时只执行了通知方法,而切入点方法没有执行

原因:

​ 通过对比动态的代理中的环绕通知代码,发现动态代理的环绕通知有明确的切入点方法调用,而本案例中的代码没有

9.5 完善aroundPringLog方法

Logger.java

/** * 用于记录日志的工具类,它里面提供了公共的代码 */public class Logger { /** * 环绕通知 * 问题: * 当我们配置了环绕通知之后,切入点方法没有执行,而通知方法执行了 * 分析: * 通过对比动态的代理中的环绕通知代码,发现动态代理的环绕通知有明确的切入点方法调用,而我们的代码中没有 * 解决: * Spring框架为我们提供了一个接口,ProceedingJoinPoint,该接口有一个方法proceed(),此方法就相当于明确调用切入点方法 * 该接口可以作为环绕通知的方法参数, 在程序执行的时候,Spring框架会为我们提供该接口供我们使用 * * Spring的环绕通知: * 他是Spring框架为我们提供的一种可以在代码中手动控制增强方法何时执行的方式 */ public Object aroundPringLog(ProceedingJoinPoint proceedingJoinPoint){ Object returnValue = null; try { Object[] args = proceedingJoinPoint.getArgs(); //得到方法执行所需要的参数 System.out.println("Logger类中的aroundPringLog方法开始记录日志了-----前置"); returnValue = proceedingJoinPoint.proceed(args); //明确调用业务层方法,切入点方法 System.out.println("Logger类中的aroundPringLog方法开始记录日志了-----后置"); return returnValue; }catch (Throwable throwable){ System.out.println("Logger类中的aroundPringLog方法开始记录日志了-----异常"); throw new RuntimeException(throwable); }finally { System.out.println("Logger类中的aroundPringLog方法开始记录日志了-----最终"); } }}

9.6 运行结果

9.7 目录结构

到此这篇关于Spring中基于XML的AOP配置的文章就介绍到这了,更多相关Sprin AOP配置内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!

声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。

相关文章