使用AOP记录SpringBoot项目编辑前后字段的具体改变

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
首先,在Spring Boot项目中引入aop和数据库配置模块: ``` <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-aop</artifactId> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-jdbc</artifactId> </dependency> ``` 然后,在application.properties中配置读写分离数据库连接信息,如下所示: ``` spring.datasource.write.jdbc-url=jdbc:mysql://localhost:3306/write_db?useUnicode=true&characterEncoding=utf-8&useSSL=false spring.datasource.write.username=root spring.datasource.write.password=root spring.datasource.read.jdbc-url=jdbc:mysql://localhost:3306/read_db?useUnicode=true&characterEncoding=utf-8&useSSL=false spring.datasource.read.username=root spring.datasource.read.password=root ``` 接着,在aop中定义切面,根据方法名判断是读操作还是写操作,并切换数据源。 ``` @Aspect @Component public class DataSourceAop { @Before("execution(* com.example.demo.service.*.*(..))") public void setDataSourceKey(JoinPoint point) { String methodName = point.getSignature().getName(); if (isSlave(methodName)) { DynamicDataSourceContextHolder.setDataSourceKey(DataSourceKey.read); } else { DynamicDataSourceContextHolder.setDataSourceKey(DataSourceKey.write); } } public boolean isSlave(String methodName) { // 判断是否为读方法 return methodName.startsWith("get") || methodName.startsWith("select") || methodName.startsWith("find"); } @After("execution(* com.example.demo.service.*.*(..))") public void clearDataSourceKey() { DynamicDataSourceContextHolder.clearDataSourceKey(); } } ``` 最后,定义一个DynamicDataSource类,该类继承AbstractRoutingDataSource类,并重写determineCurrentLookupKey方法,用于

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值