Spring-Day7
17.AOP
AOP意为:面向切面编程,通过预编译方式和运行期动态代理实现程序功能的统一维护的一种技术,AOP是OOP的延续,是软件开发中的一个热点,也是Spring框架中的一个重要内容,是函数式编程的一种衍生泛型。利用AOP可以对业务逻辑的各个部分进行隔离,从而使得业务逻辑各部分之间的耦合度降低,提高程序的可重用性,同时提高了开发的效率
AOP在Spring中的作用
-
横切关注点:跨越应用程序多个模块的方法或功能。即是,与我们业务逻辑无关的,但是我们需要关注的部分,就是横切关注点。如日志,安全,缓存,事务等等
-
切面:横切关注点 被模块化 的特殊对象。即,它是一个类
-
通知:切面必须要完成的工作。即,它是类中的一个方法
-
目标:被通知对象
-
代理:向目标对象应用通知之后创建的对象
-
切入点:切面通知 执行的“地点”的定义
-
连接点:与切入点匹配的执行点
使用AOP,需要导入一个依赖包
<dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-aop</artifactId> <dependency>
编写一个UserService
@Service public class UserService { public void add() { System.out.println("添加用户"); } public void delete() { System.out.println("删除用户"); } public void update() { System.out.println("修改用户"); } public void query() { System.out.println("查找用户"); } }
编写好LogAspect
@Aspect // 标记为了切面类 @Component // 必须声明为 Spring 的 bean public class LogAspect { // 实现方法用时 切点表达式 // 环绕通知 @Around("execution(* com.example.demo.UserService.*(..) )") public void log(ProceedingJoinPoint proceedingJoinPoint) { // 记录方法用时 long start = System.currentTimeMillis(); // 执行具体的方法 try{ proceedingJoinPoint.proceed(); } catch (Throwable e) { System.out.println("方法执行异常:" + e.getMessage()); } long end = System.currentTimeMillis(); System.out.println("方法用时:" + (start - end) + "ms"); } }
编写好启动类
@SpringBootTest (classes = C4AopApplicationTests.class) @ComponentScan class C4AopApplicationTests { @Test void contextLoads(@Autowired UserService userService) { userService.add(); } }
启动后成功完成添加用户等操作!
如何在Spring中创建一个所谓的切面? @Aspect + @Component + 通知 + 切点