配置切点:
//自定义注解方式
@Pointcut("@annotation(com.example.aop_test.annotation.OperationAnnonation)")
public void pointcut(){
}
//粒度精确至方法级别方式
@Pointcut("execution(public * com.example.aop_test.controller.TestController.test2(..))")
public void Giaopointcut(){
}
以上两种方式详解:
-
第一种方式是配合自定义注解使用,将切点指向自定义注解,然后在需要执行操作的方法上加上注解即可;
-
第二种方式是指定具体方法的路径,需要区分方法名以及方法参数,在执行时即可在运行到这个方法时自动执行切面代码;
2.1.无参方法(方法括号内不需要写参数):@Pointcut("execution(public * com.example.aop_test.controller.TestController.test2())")
2.2. 有参方法(如果有参数可以写具体的参数类型,如果不想写,也可以像示例一样写两个点表示通配符):
@Pointcut("execution(public * com.example.aop_test.controller.TestController.test2(..))")
2.3. 引申:原文戳这里
配合自定义注解使用:
自定义注解:
@Target(ElementType.METHOD)
@Retention(RetentionPolicy.RUNTIME)
@Documented
public @interface OperationAnnonation {
String userName() default "";
String operationMes() default "";
String deviceId() default "";
String deviceName() default "";
}
需要执行操作的方法:
@OperationAnnonation
@GetMapping("/")
public String test(){
return "这里是test方法!";
}
配置切面:
@AfterReturning(value = "pointcut()",returning = "object")
public void operation(JoinPoint point,Object object){
System.out.println("aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa");
System.out.println("返回值::::::::"+object.toString());
}
相关引申文章: