Spring Boot入门(23):【实战】通过AOP拦截Spring Boot日志并将其存入数据库

ops/2024/12/22 20:13:05/

在Spring Boot应用中,通过AOP(面向切面编程)拦截日志并将其存入数据库是一个常见的需求,可以帮助开发者更好地监控应用的运行状态和问题排查。以下是实现这一功能的基本步骤:

1. 引入依赖

首先,确保你的pom.xmlbuild.gradle文件中包含了Spring Boot和数据访问相关的依赖。

对于Maven,添加如下依赖:

<dependencies><!-- Spring Boot Starter AOP --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-aop</artifactId></dependency><!-- Spring Boot Starter Data JPA --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-jpa</artifactId></dependency><!-- 选择一个数据库驱动,例如H2 --><dependency><groupId>com.h2database</groupId><artifactId>h2</artifactId><scope>runtime</scope></dependency><!-- 其他依赖 -->
</dependencies>

2. 配置数据访问

创建一个实体类LogEntry来映射数据库中的日志记录。

import javax.persistence.*;
import java.time.LocalDateTime;@Entity
public class LogEntry {@Id@GeneratedValue(strategy = GenerationType.IDENTITY)private Long id;private String message;private LocalDateTime timestamp;// 省略getter和setter方法
}

配置数据源和JPA。

# src/main/resources/application.yml
spring:datasource:url: jdbc:h2:mem:testdbdriverClassName: org.h2.Driverusername: sapassword: passwordjpa:hibernate:ddl-auto: create-dropproperties:hibernate:show_sql: true

3. 创建日志存储服务

创建一个服务类,用于将日志信息存储到数据库

import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;@Service
public class LogService {private final LogRepository logRepository;public LogService(LogRepository logRepository) {this.logRepository = logRepository;}@Transactionalpublic void save(String message) {LogEntry logEntry = new LogEntry();logEntry.setMessage(message);logEntry.setTimestamp(LocalDateTime.now());logRepository.save(logEntry);}
}

4. 创建日志拦截器

使用AOP创建一个日志拦截器,该拦截器将日志信息传递给LogService

import org.aspectj.lang.annotation.Aspect;
import org.aspectj.lang.annotation.Before;
import org.aspectj.lang.annotation.Pointcut;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Component;@Aspect
@Component
public class LogAspect {private static final Logger logger = LoggerFactory.getLogger(LogAspect.class);@Autowiredprivate LogService logService;@Pointcut("execution(* com.example.demo.*.*(..))")public void logAround() {}@Before("logAround()")public void before(JoinPoint joinPoint) {// 这里可以根据需要记录日志的具体内容String logMessage = "Method: " + joinPoint.getSignature().getName();logService.save(logMessage);}
}

5. 配置AOP

在Spring Boot的主配置类中启用AOP。

import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.boot.autoconfigure.aop.AopAutoConfiguration;@SpringBootApplication(exclude = AopAutoConfiguration.class)
public class DemoApplication {public static void main(String[] args) {SpringApplication.run(DemoApplication.class, args);}
}

6. 运行和验证

启动你的Spring Boot应用,并进行一些操作以生成日志。然后,检查数据库以确认日志已经被存储。

这个例子展示了如何使用Spring AOP拦截方法调用并将日志存储到数据库。你可以根据需要修改拦截器,以适应不同的日志记录需求。


http://www.ppmy.cn/ops/14442.html

相关文章

PE结构(二)PE头字段说明

PE头字段 DOS头 PE标记 标准PE头 可选PE头 我们今天分析一下PE头字段中所有重要成员的含义 DOS头 DOS头中我们需要去分析的是如下两个成员&#xff1a; 1.WORD e_magic&#xff1a;MZ标记&#xff0c;用于判断是否为可执行文件&#xff0c;即如果显示4D 5A&#xff0c;…

51单片机入门_江协科技_35~36_OB记录的自学笔记_AD与DA转换(XPT2046)

35. AD_DA 35.1. AD/DA介绍 •AD&#xff08;Analog to Digital&#xff09;&#xff1a;模拟-数字转换&#xff0c;将模拟信号转换为计算机可操作的数字信号 •DA&#xff08;Digital to Analog&#xff09;&#xff1a;数字-模拟转换&#xff0c;将计算机输出的数字信号转换…

绿色便携方式安装apache+mysql+tomcat+php集成环境并提供控制面板

绿色便携方式安装带控制面板的ApacheMariaDBTomcatPHP集成环境 目录 绿色便携方式安装带控制面板的ApacheMariaDBTomcatPHP集成环境[TOC](目录) 前言一、XAMPP二、安装和使用1.安装2.使用 三、可能的错误1、检查端口占用2、修改端口 前言 安装集成环境往往配置复杂&#xff0c…

数据结构之双链表的相关知识点及应用

找往期文章包括但不限于本期文章中不懂的知识点&#xff1a; 个人主页&#xff1a;我要学编程(ಥ_ಥ)-CSDN博客 所属专栏&#xff1a;数据结构 目录 双链表的实现 初始化双链表 在双链表中尾插数据 在双链表中尾删数据 在双链表中头插数据 在双链表中头删数据 在双…

课时105:正则表达式_进阶知识_扩展符号

1.1.1 扩展符号 学习目标 这一节&#xff0c;我们从 基础知识、简单实践、小结 三个方面来学习 基础知识 简介 字母模式匹配[:alnum:] 字母和数字[:alpha:] 代表任何英文大小写字符&#xff0c;亦即 A-Z, a-z[:lower:] 小写字母,示例:[[:lower:]],相当于[a-z][:upper:] 大…

智慧物流时代:数字化转型下的物流新篇章

一、什么是智慧物流&#xff1f; 智慧物流是一种利用先进科技和信息技术优化物流供应链系统的新型模式。以数据为核心&#xff0c;智慧物流通过物联网、云计算、大数据和人工智能等技术手段实现物流信息的全面记录、无缝对接和智能化处理。其核心在于实现物流各环节的精细化、…

Spark pivot数据透视从句

1. 概念2. 实战 2.1. 新列的决定因素2.2. 新列别名2.3. column_list中指定多个字段2.4. 多个聚合函数的使用2.5. 最终出现在SQL结果中的决定因素 Spark pivot数据透视从句 1. 概念 描述 用于数据透视&#xff0c;根据特定的列获取聚合值&#xff0c;聚合值将转换为select子句…

Vue接收接口返回的mp3格式数据并支持在页面播放音频

一、背景简介 在实际工作中需要开发一个转音频工具&#xff0c;并且能够在平台页面点击播放按钮播放音频 二、相关知识介绍 2.1 JS内置对象Blob Blob对象通常用于处理大量的二进制数据&#xff0c;可以读取/写入/操作文件、音视频等二进制数据流。Blob表示了一段不可变的二…