AOP+SpEL实现日志记录

本文探讨了如何在Spring AOP中利用SpEL解析技术,实现在缓存注解和日志注解中动态参数的处理,包括@Cached和@CkOperatedLog注解的使用实例,以及自定义注解的AOP拦截和参数替换过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

大家先思考一个问题,缓存注解和日志注解上#后面跟的动态参数是怎么解析出来的
方法上缓存注解

@Cached(name = "cktest", key = "#sjzxDbname + #sjzxTable", cacheType = CacheType.LOCAL, expire = Integer.MAX_VALUE, localLimit = 1500)

方法上日志注解

@CkOperatedLog(module = "test", operation = "find", description = "查询test2接口", param = "'zdmc='+#vo.zdmc")

下面就是利用AOP+SpEL实现日志记录

使用spring的AOP需要引入除springboot坐标外,还需要引入一个坐标

<dependency>
    <groupId>org.aspectj</groupId>
    <artifactId>aspectjweaver</artifactId>
</dependency>

自定义日志注解

@Retention(RetentionPolicy.RUNTIME)
@Target({
   
   ElementType.METHOD})
@Documented
public @interface CkOperatedLog {
   
   

    /**
     * 所属模块
     */
    String module() default "";

    /**
     * 操作类型add,del等
     */
    String operation() default ""
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值