SpringBoot:通过AOP+注解优雅实现操作日志记录

在开发过程中,我们经常需要记录用户的操作日志,例如用户的登录、新增、修改、删除等操作。为了更加优雅地实现操作日志记录,我们可以借助Spring Boot的AOP和注解来实现。

首先,我们需要创建一个注解@Log,用来声明哪些方法需要记录操作日志。可以在类级别或者方法级别使用该注解。例如:

java 复制代码
@Log("新增用户") // 在方法上使用注解
@PostMapping("/users")
public User createUser(@RequestBody User user) {
    // 创建用户逻辑
}

接下来,我们需要创建一个切面类LogAspect,用来处理@Log注解的逻辑。在切面类中,我们可以获取到方法的参数、返回值等信息,进而记录对应的操作日志。

java 复制代码
@Aspect
@Component
public class LogAspect {

    @Autowired
    private LogService logService;

    @Pointcut("@annotation(com.example.demo.annotation.Log)")
    public void logPointCut() {
    }

    @AfterReturning(pointcut = "logPointCut()", returning = "returnValue")
    public void afterReturning(JoinPoint joinPoint, Object returnValue) {
        // 获取方法的参数、返回值等信息
        String methodName = joinPoint.getSignature().getName();
        Object[] args = joinPoint.getArgs();
        // ...
        // 记录操作日志
        Log log = joinPoint.getMethod().getAnnotation(Log.class);
        logService.saveLog(log.value(), methodName, args, returnValue);
    }
}

在切面类中,我们使用@Pointcut注解来声明@Log注解的切入点,使用@AfterReturning注解来处理方法执行完毕后的逻辑。在afterReturning方法中,我们可以通过joinPoint参数获取到方法的相关信息,并调用logService来保存操作日志。

最后,我们需要定义一个LogService来实现将操作日志保存到数据库或者其他日志存储方式。

java 复制代码
@Service
public class LogService {

    public void saveLog(String action, String methodName, Object[] args, Object returnValue) {
        // 将操作日志保存到数据库或者其他日志存储方式
    }
}

通过以上步骤,我们就可以实现通过AOP+注解优雅地实现操作日志记录了。在需要记录操作日志的方法上添加@Log注解,就可以自动记录对应的操作日志了。

相关推荐
a11177621 小时前
快速制作 虚拟形象项目 MotionPNGTuber
python·live2d
一切尽在,你来21 小时前
AI大模型应用开发前置知识:Python迭代器和生成器深入详解
python·langchain·ai编程
大黄评测21 小时前
Spring Boot 集成 Nacos 完全指南:从配置中心到服务发现一站式实战
后端
大鹏198821 小时前
Java Swing 界面美化与 JPanel 优化完全指南:从复古到现代的视觉革命
后端
大尚来也21 小时前
.NET 10 Minimal APIs 主要应用场景全景指南:从原型到企业级生产
后端
大黄评测21 小时前
.NET 10 & C# 14 新特性详解:扩展成员 (Extension Members) 全面指南
后端
小雨中_21 小时前
2.7 强化学习分类
人工智能·python·深度学习·机器学习·分类·数据挖掘
摩拜芯城IC1 天前
ATSHA204A‑STUCZ CryptoAuthentication 安全认证芯片IC
python·安全
苏渡苇1 天前
轻量化AI落地:Java + Spring Boot 实现设备异常预判
java·人工智能·spring boot·后端·网络协议·tcp/ip·spring
小雨中_1 天前
2.4 贝尔曼方程与蒙特卡洛方法
人工智能·python·深度学习·机器学习·自然语言处理