SpringBoot + AOP的简单使用
- 添加DTO
- 添加controller(同包不同类)
- 控制器1
- 控制器2
- AOP场景演示
- 1. 对某package下的所有接口进行方法执行前逻辑校验
- 新增切面,编写处理逻辑
- 2. 对某controller类下的所有接口进行方法执行前逻辑校验
- 新增切面,编写处理逻辑
- 3. 对某注解修饰的所有接口进行方法执行前逻辑校验
- 自定义注解
- 在控制器1 test 方法前修饰自定义注解
- 新增切面,编写处理逻辑
添加DTO
@Data
@Accessors(chain = true)
public class Test {
private String sex;
private String name;
}
添加controller(同包不同类)
控制器1
package com.test.controller;
@Slf4j
@RestController
@RequestMapping("/v1/aop_test")
public class AopController {
@PostMapping("/test")
public Test test(@RequestBody Test dto) {
return dto;
}
@PostMapping("/testList")
public List<Test> testList(@RequestBody List<Test> list) {
return list;
}
}
控制器2
package com.test.controller;
@Slf4j
@RestController
@RequestMapping("/v1/aop_test_second")
public class ApoTestSecondController {
/**
* 根据参数请求接口
*
* @return
*/
@PostMapping(path = "/test")
public void test(@RequestBody @Valid Test dto) {
log.info("aop_test_second test {}......",dto.toString());
}
}
AOP场景演示
以下场景可以叠加。
1. 对某package下的所有接口进行方法执行前逻辑校验
新增切面,编写处理逻辑
@Aspect
@Component
public class AopControllerPackageConfig {
@Before("execution(* com.test.controller.*.*(..))")
public void beforeAop(JoinPoint joinPoint) {
RequestAttributes requestAttributes = RequestContextHolder.getRequestAttributes();
HttpServletRequest request = ((ServletRequestAttributes) requestAttributes).getRequest();
System.out.println("AopControllerPackageConfig 方法请求路径:" + request.getRequestURI());// 方法请求路径
System.out.println("AopControllerPackageConfig 请求方式:" + request.getMethod());// 请求方式
System.out.println("AopControllerPackageConfig 请求参数:" + JSON.toJSONString(joinPoint.getArgs()));// 请求参数(数组类型)
}
}
2. 对某controller类下的所有接口进行方法执行前逻辑校验
新增切面,编写处理逻辑
@Aspect
@Component
public class AopControllerConfig {
@Before("execution(* com.test.controller.AopController.*(..))")
public void beforeAop(JoinPoint joinPoint) {
RequestAttributes requestAttributes = RequestContextHolder.getRequestAttributes();
HttpServletRequest request = ((ServletRequestAttributes) requestAttributes).getRequest();
System.out.println("AopControllerConfig 方法请求路径:" + request.getRequestURI());// 方法请求路径
System.out.println("AopControllerConfig 请求方式:" + request.getMethod());// 请求方式
System.out.println("AopControllerConfig 请求参数:" + JSON.toJSONString(joinPoint.getArgs()));// 请求参数
}
}
3. 对某注解修饰的所有接口进行方法执行前逻辑校验
自定义注解
package com.test.annotations;
@Documented
@Target(ElementType.METHOD)
@Retention(RetentionPolicy.RUNTIME)
public @interface PermissionValid {
String value() default "";
}
在控制器1 test 方法前修饰自定义注解
@PermissionValid("我是值")
@PostMapping("/test")
public Test test(@RequestBody Test dto) {
return dto;
}
新增切面,编写处理逻辑
@Aspect
@Component
public class AopConfig {
@Before("@annotation(com.test.annotations.PermissionValid)")
public void beforeAop(JoinPoint joinPoint) {
RequestAttributes requestAttributes = RequestContextHolder.getRequestAttributes();
HttpServletRequest request = ((ServletRequestAttributes) requestAttributes).getRequest();
System.out.println("AopConfig 方法请求路径:" + request.getRequestURI());// 方法请求路径
System.out.println("AopConfig 请求方式:" + request.getMethod());// 请求方式
System.out.println("AopConfig 请求参数:" + JSON.toJSONString(joinPoint.getArgs()));// 请求参数
// 获取目标方法
MethodSignature signature = (MethodSignature) joinPoint.getSignature();
Method method = signature.getMethod();
// 获取方法上的注解
PermissionValid annotation = method.getAnnotation(PermissionValid.class);
if (annotation != null) {
String value = annotation.value(); // 获取注解的value值
System.out.println("注解值:" + value);
}
}
}