AOP(面向切面编程)的核心概念是"切面"。
切面是一个跨越多个对象的类,它封装了横切关注点的具体实现。通过定义切面,开发人员可以将通用功能从业务逻辑中分离出来,形成独立的模块。在Spring AOP中,切面由切点(Pointcut)、通知(Advice)和连接点(Joinpoint)组成。切点用于定义哪些连接点上应该应用通知,而通知则是在连接点处执行的代码。
AOP通过将横切关注点与主业务逻辑进行解耦,实现了关注点的模块化和可重用性。这种编程范式提高了代码的组织性、可维护性和可扩展性,使得开发人员可以更容易地管理和维护复杂的软件系统。
试用场景:
有100个类,希望给这个100个类执行前,执行后都加入日志,记录执行的开始时间和结束时间,使用切面写一个类就可以搞定,不用把写日志的操作在100个方法里都写一遍。如下看如何实现:
一、依赖
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-aop</artifactId>
</dependency>
二、工程结构
data:image/s3,"s3://crabby-images/8a56f/8a56ff05af27425e66c36de89a1d7c540f1807a3" alt=""
三、启动类
data:image/s3,"s3://crabby-images/9451d/9451d88a02758c436afb2dd6b99016a06c61e723" alt=""
四、切面类
data:image/s3,"s3://crabby-images/214bd/214bdf6a7f47ac688c3ae8cbc6f43e34c430158c" alt=""
五、方法类
data:image/s3,"s3://crabby-images/3cf80/3cf8015ec6a5b5b325499ecd9d0d84916a9f4114" alt=""
六、测试类
data:image/s3,"s3://crabby-images/687ae/687ae5d88c1a2de5ace2afb3084c7b2ca7a55122" alt=""
七、测试运行
1、指定切面类应用的对象所在的包
(1)execution(* com.example.service.*.*(..))
(2)完整的切面类 如下:
data:image/s3,"s3://crabby-images/aad05/aad05526ec13e98f5d30592a09bbe3d64cb1f1d9" alt=""
(3)执行的具体方法
data:image/s3,"s3://crabby-images/71b46/71b466dd70f3fb6d903ba8764b95f0e92e8f4016" alt=""
(4)执行
data:image/s3,"s3://crabby-images/9302d/9302d61e8b75b28ad32f57a0109b6d2f2f175752" alt=""
(5)输出
data:image/s3,"s3://crabby-images/6ca2a/6ca2a2199d0c689bcd75f1e1a395d3eaa3c9f750" alt=""
2、修改前置方法指定的类
(1)切面类修改
data:image/s3,"s3://crabby-images/66e7a/66e7aeb184680dd1dfcd45813a9d59db8ba031bd" alt=""
(2)另一个类中的方法
data:image/s3,"s3://crabby-images/3bbb4/3bbb40c590051019e88d09ee99193ca0fb4168e3" alt=""
(3)分别运行如下两个测试方法
data:image/s3,"s3://crabby-images/3e8f4/3e8f46a6cb6e17782f7f640857513a6071eadc0e" alt=""
(4)输出
data:image/s3,"s3://crabby-images/0a7ac/0a7acefa999dbfdd7d97ce092ebf08d5a96f628d" alt=""
3、修改前置方法指定的方法
(1)指定到方法
data:image/s3,"s3://crabby-images/83d25/83d25ce881e065817a97f3774e227332465cfb91" alt=""
(2)分别运行如下两个测试方法
data:image/s3,"s3://crabby-images/db4df/db4dfece785f42ca0a2949a80e88a042388d5091" alt=""
(3)结果:第二个方法缺少前置输出,说明切面的前置输出只对第一个方法起作用
data:image/s3,"s3://crabby-images/330b2/330b2969def411b94be477d94b54dbd5d5c6ff11" alt=""
源码获取方式(免费):
(1)登录-注册:http://resources.kittytiger.cn/
(2)搜索:springboot-AOP切面编程的demo