一、新建一个类,AOP用来增强该类的方法
package com.example.demo.aop;
import org.springframework.stereotype.Component;
@Component
public class AopService {
public void testAop(int id) {
System.out.println("【Test Aop id = " + id + "】");
}
}
二、创建AOP的注解,进行切面编程
package com.example.demo.aop;
import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.annotation.*;
import org.springframework.stereotype.Component;
@Aspect
@Component
public class MyAopAspect {
// 【配置切点 及要传的参数】
@Pointcut("execution(* com.example.demo.aop.AopService.testAop(..)) && args(id)")
public void pointCut(int id) {
}
// 前置通知
@Before("pointCut(id)")
public void before(int id) {
System.out.println("【前置通知】id=" + id);
}
// 环绕通知
@Around("pointCut(id)")
public Object aroundLog(ProceedingJoinPoint joinpoint, int id) {
Object res = null;
try {
System.out.println("【环绕通知】Begin, id=" + id);
long start = System.currentTimeMillis();
// 有返回参数 则需返回值
res = joinpoint.proceed();
long end = System.currentTimeMillis();
System.out.println("【方法耗时】" + (end - start) + " ms");
System.out.println("【环绕通知】End, id=" + id);
} catch (Throwable e) {
System.out.println("【环绕通知异常】" + e.getMessage());
}
return res;
}
// 后置通知
@After("pointCut(id)")
public void after(int id) {
System.out.println("【后置通知】id=" + id);
}
// 方法执行完成
@AfterReturning("pointCut(id)")
public void afterReturning(int id) {
System.out.println("【方法执行完成】id=" + id);
}
// 方法异常
@AfterThrowing("pointCut(id)")
public void afterThrowingLog(int id) {
System.out.println("【方法异常】id=" + id);
}
}
三、测试
package com.example.demo;
import com.example.demo.aop.AopService;
import org.junit.jupiter.api.Test;
import org.junit.runner.RunWith;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.test.context.junit4.SpringRunner;
@RunWith(SpringRunner.class)
@SpringBootTest
class MyTest {
@Autowired
private AopService aopService;
@Test
public void testAop() {
//AOP使用注解
aopService.testAop(100);
}
}
四、相关依赖包
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-aop</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>