前期准备
pom.xml引入aop包,版本不用跟例子一致
<!-- https://mvnrepository.com/artifact/org.springframework.boot/spring-boot-starter-aop -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-aop</artifactId>
<version>2.6.4</version>
</dependency>
项目目录结构:
接着来实现简单aop功能
实现逻辑:1.先定义具有切面功能的类 2.定义切点 3.定义功能运行的时间位置
@Aspect表明这个是组织了切面逻辑的类
@pointcut定义切点(用于指定需要面向编程的面),定义的切点表达式可网上查询
@Before,@After都是定义逻辑执行的时间位置,还有其他的类就不展开写
@Aspect
@Component
public class ControllerAspect {
//定义切点
@pointcut("execution(public * com.rmx.learn.controller..*Controller.*(..))")
public void controllerpointcut(){};
@Before("controllerpointcut()")
public void before(){
System.out.println("进入切点前");
}
@After("controllerpointcut()")
public void after(){
System.out.println("进入切点后");
}
}
@RestController
public class TestController {
@RequestMapping("/test")
public void print(){
System.out.println("控制器");
}
}
写完控制器后,可以直接运行调用控制器查看AOP功能是否运行了,不过这里我不想打开页面测试,我就写了测试文件
http://localhost:8080/test
实现结果