当前位置:主页 > >

springboot 使用自定义的aspect的示例代码

时间:2020-08-06 10:00:05 | 栏目: | 点击:

对某个类型中的方法进行拦截,然后加入固定的业务逻辑,这是AOP面向切面编程可以做的事,在springboot里实现aop的方法也有很多, spring-boot-starter-aop 或者 aspectjweaver 都是可以实现的,不过我们在实现之前,先来看一下aop里的几个概念。

概念

实现

1 引用依赖包

<dependency>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-starter-aop</artifactId>
 </dependency>

2 添加切面和拦截的行为

@Aspect
@Component
@Slf4j
public class TestAspect {

 /**
  * 对TestService类下面的所有方法拦截.
  */
 @Pointcut("execution(* com.lind.start.test.aop.TestService.*(..))")
 public void pointcut() {
 }

 //前置通知
 @Before("pointcut()")
 public void beforeMethod(JoinPoint joinPoint) {
  if (joinPoint.getArgs().length == 1 && joinPoint.getArgs()[0] instanceof User) {
   User user = (User) joinPoint.getArgs()[0];
   user.setUsername("aop赋值");
   log.info("调用了前置通知" + user.toString());
  }

 }

 //@After: 后置通知
 @After("pointcut()")
 public void afterMethod(JoinPoint joinPoint) {
  log.info("调用了后置通知");
 }

 //@AfterRunning: 返回通知 result为返回内容
 @AfterReturning(value = "pointcut()", returning = "result")
 public void afterReturningMethod(JoinPoint joinPoint, Object result) {
  log.info("调用了返回通知");
 }

 //@Around:环绕通知
 @Around("pointcut()")
 public Object Around(ProceedingJoinPoint pjp) throws Throwable {
  log.info("around执行方法之前");
  Object object = pjp.proceed();
  log.info("around执行方法之后--返回值:" + object);
  return object;
 }

}

3 调用及结果

@SpringBootTest
@RunWith(SpringRunner.class)
public class AopTest {
 @Autowired
 TestService testService;

 @Test
 public void test() {
  testService.print(new User());
 }
}

总结

您可能感兴趣的文章:

相关文章