java

关注公众号 jb51net

关闭
首页 > 软件编程 > java > AOP在SpringBoot的使用场景

AOP在SpringBoot项目中的使用场景解读

作者:她又在丛中笑

本文介绍如何使用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);
        }
    }
}

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

您可能感兴趣的文章:
阅读全文