AOP在SpringBoot项目中的简单使用场景

添加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);
        }
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值