SpringBoot3.5.4 AOP环绕通知使用

依赖

web和aop依赖

复制代码
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>3.5.4</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>
    <groupId>org.example</groupId>
    <artifactId>demo</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <name>demo</name>
    <description>demo</description>
    <url/>
    <licenses>
        <license/>
    </licenses>
    <developers>
        <developer/>
    </developers>
    <scm>
        <connection/>
        <developerConnection/>
        <tag/>
        <url/>
    </scm>
    <properties>
        <java.version>17</java.version>
    </properties>
    <dependencies>
        <!-- Web 开发 -->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>

        <!-- AOP,用于实现自定义注解功能 -->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-aop</artifactId>
        </dependency>

        <!-- 测试依赖,Spring Boot 3.x 用这个 -->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
    </dependencies>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>

</project>

自定义注解

复制代码
package com.example.demo.annotation;

import java.lang.annotation.*;

@Retention(RetentionPolicy.RUNTIME)
@Target(ElementType.METHOD)
public @interface MyLog {

    String value() default "";
}

注解的AOP配置 环绕通知

复制代码
package com.example.demo.aop;

import com.example.demo.annotation.MyLog;
import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.annotation.*;
import org.springframework.stereotype.Component;

@Aspect
@Component
public class MyLogAspect {
    @Around("@annotation(myLog)")
    public Object around(ProceedingJoinPoint joinPoint, MyLog myLog) throws Throwable {
        System.out.println("日志开始:" + myLog.value());
        Object result = joinPoint.proceed();
        System.out.println("日志结束:" + myLog.value());
        return result;
    }
}

在控制器中使用

复制代码
package com.example.demo.controller;

import com.example.demo.annotation.MyLog;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;

@RestController
public class DemoController {




    @MyLog("xxx")
    @GetMapping("/hello")
    public String hello() {
        return "<h1>Hello World!</h1>";
    }
}

访问http://localhost:8080/hello

默认AOP是同步的,如果你希望异步

复制代码
@Around("@annotation(myLog)")
public Object around(ProceedingJoinPoint joinPoint, MyLog myLog) throws Throwable {
    System.out.println("日志开始:" + myLog.value());

    Object result = joinPoint.proceed();

    new Thread(() -> {
        System.out.println("异步保存日志:" + myLog.value());
    }).start();

    return result;
}
相关推荐
西安邮电大学1 小时前
Redis四大经典缓存问题
java·redis·后端·其他·面试
超梦dasgg2 小时前
Redisson解锁失败,WatchDog会不会一直续期下去?
java·redis
Chase_______2 小时前
【Java基础 | 11】异常处理进阶:throw、throws、自定义异常与异常链讲清楚
java·开发语言·python
DFT计算杂谈2 小时前
VASP 磁性结构可视化:一键生成完美 VESTA / MCIF
java·前端·css·html·css3
砍材农夫2 小时前
物联网实战:Spring Boot MQTT | 模拟器Paho客户端拆解核心点
java·javascript·网络·spring boot·后端·物联网
weixin_539446782 小时前
使用Java HttpServletResponse和JavaScript Fetch下载文件
java·javascript·python
我登哥MVP2 小时前
Spring Boot 从“会用”到“精通”:自动装配原理
java·spring boot·后端·spring·tomcat·maven·intellij-idea
小的~~2 小时前
Java线程及线程池的相关的问题
java·开发语言·多线程
爱吃羊的老虎2 小时前
【JAVA】Java微服务—网关Gateway
java·微服务·gateway