AOP在SpringBoot项目中的使用场景解读
更新时间:2026年01月09日 09:16:30 作者:她又在丛中笑
本文介绍如何使用AOP在不同场景下对方法执行前进行逻辑校验,包括对整个包下、特定控制器下以及特定注解修饰的方法进行校验,通过自定义注解和切面实现,展示了AOP的灵活性和强大功能
添加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);
}
}
}
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
您可能感兴趣的文章:
- SpringBoot 拦截器 (Interceptor)与切面 (AOP)示例、作用及适用场景分析
- SpringBoot整合Jasypt使用自定义注解+AOP实现敏感字段加解密
- Springboot如何正确使用AOP问题
- springboot接口服务,防刷、防止请求攻击,AOP实现方式
- SpringBoot3利用AOP实现IP黑名单功能
- springbootAOP定义切点获取/修改请求参数方式
- SpringBoot实现AOP切面的三种方式
- SpringBoot中使用AOP实现日志记录功能
- SpringBoot AOP如何配置全局事务
- JAVA中Spring Boot的AOP切面编程是什么,如何使用?(实例代码)
相关文章
Mybatis中${param}与#{param}的区别说明
这篇文章主要介绍了Mybatis中${param}与#{param}的区别说明,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教2022-06-06


最新评论