Spring AOP 使用 SPEL 表达式记录日志

Spring AOP 使用 SPEL 表达式记录日志

需求来源

由于项目中需要记录操作日志,并且需要记录具体的细节操作,比如:新增用户,我们需要记录如下日志:
新增用户,用户名为:xxxx
获取参数xxxx的这个步骤,起始可以做到,但是一般做法是获取到方法的全部参数,这样记录的日志内容并不是很好看
所有我就想,会不会有支持 SPEL 表达式的方式,结果一百度,还真有,话不多说,现在记录下探索的过程

参考链接

实现过程

  1. 自定义注解类
@Target(ElementType.METHOD)
@Retention(RetentionPolicy.RUNTIME)
@Documented
public @interface AuditLog {

    String name() default "";

    String code() default "";

	//这个记录具体操作日志内容,可以支持SPEL表达式
    String content() default "";
}
  1. 自定义切面,实现逻辑
@Log4j2
@Aspect
@Component
public class AuditAspect {

	//解析spel表达式
    ExpressionParser parser = new SpelExpressionParser();
    //将方法参数纳入Spring管理
    LocalVariableTableParameterNameDiscoverer discoverer = new LocalVariableTableParameterNameDiscoverer();

    @Pointcut("@annotation(com.lcsoft.aop.AuditLog)")
    public void logPointCut() {}

    @Around("logPointCut()")
    public Object invoked(ProceedingJoinPoint pjp) throws Throwable {
        //获取参数对象数组
        Object[] args = pjp.getArgs();
        //获取方法
        Method method = ((MethodSignature) pjp.getSignature()).getMethod();
        AuditLog log = method.getAnnotation(AuditLog.class);
        String spel = log.content();
        //获取方法参数名
        String[] params = discoverer.getParameterNames(method);
        //将参数纳入Spring管理
        EvaluationContext context = new StandardEvaluationContext();
        for (int len = 0; len < params.length; len++) {
            context.setVariable(params[len], args[len]);
        }
        Expression expression = parser.parseExpression(spel);
        spel = expression.getValue(context, String.class);
        System.err.println("---------->>>>审计日志内容为:" + spel);
        return pjp.proceed();
    }
}
  1. 使用注解,在需要记录日志的方法上,添加注解
    注意:spel表达式与不同字符串之间要有分隔,不然会报错
    @ApiOperation(value = "获取我的应用")
    @GetMapping("/mine")
    @AuditAnnotation(content = "'角色id为' + #roleId + '的角色获取应用'")
    public Result mine(@RequestParam(defaultValue = "", required = false) String roleId) {}
  1. 效果
---------->>>>审计日志内容为:角色id为373faa6a6f8541b8bfa4bf60bcce9318的角色获取应用

心得

整个过程还是比较简单的,我这里只是简单实现了功能,具体项目中尚需调整,比如:将日志记录到数据库或其他数据源等,这些具体怎么记录,每个人的具体实现就看你们自己啦!!!

加油!!!

  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: Spring AOPSpring框架的一部分,主要用于在应用程序的不同部分之间进行面向切面编程(AOP)。AOP是一种编程范式,可以将应用程序的关注点分离,使应用程序更具可重用性和可维护性。 Spring AOP使用代理模式在运行时织入额外的功能,可以在方法调用前后、异常处理等方面添加额外的逻辑。使用Spring AOP可以将应用程序的关注点(如事务处理、日志记录等)分离出来,从而提高应用程序的可维护性和可重用性。 Spring AOP支持使用AspectJ注解和XML配置两种方式来定义切面。Spring AOP还提供了一个强大的表达式语言(Spring Expression Language,简称SpEL),用于在运行时动态地匹配连接点。 总的来说,Spring AOP是一个非常强大的AOP框架,可以帮助我们更好的管理应用程序的关注点,提高应用程序的可维护性和可重用性。 ### 回答2: Spring AOP(面向切面编程)是Spring框架的一个核心模块,用于实现跨应用程序模块的关注点分离。它通过在系统中将横切关注点从业务逻辑中分离出来,实现了代码的重用性、可维护性和扩展性。 Spring AOP基于代理模式,通过动态代理技术在运行时将通用的横切关注点织入目标对象中,从而实现了对目标对象方法的拦截和增强。Spring AOP主要通过使用切面、切点、通知和连接点等概念来实现。 - 切面(Aspect):切面是一个模块,它包含了一组与横切关注点相关的通知和切点。通常,一个应用程序由多个切面组成,每个切面负责某个特定的关注点。比如,日志记录、性能监控等都可以作为切面。 - 切点(Pointcut):切点定义了在哪些目标对象方法上应用通知。它使用表达式来匹配目标对象中的方法。比如,通过使用通配符等方式,我们可以定义一个切点来匹配所有的Service层方法。 - 通知(Advice):通知定义了在切点上执行的行为。Spring AOP提供了五种类型的通知:前置通知(Before)、后置通知(AfterReturning)、异常通知(AfterThrowing)、最终通知(After)和环绕通知(Around)。通过在切面中配置不同类型的通知,我们可以在目标对象方法的不同执行阶段执行相应的操作。 - 连接点(Joinpoint):连接点是在目标对象中匹配到切点的特定位置,比如方法的调用、方法的返回等。在连接点上,可以执行相应的通知。 Spring AOP的主要优势是它能够将关注点分离,使开发人员更关注业务逻辑而不是横切关注点的实现。通过使用Spring AOP,我们可以实现日志记录、事务管理、性能监控等与业务逻辑无关的功能,增加了代码的可维护性和可重用性。此外,Spring AOP还提供了灵活的配置方式,可以使用XML配置或基于注解的方式来定义切面和通知,使代码更加简洁和易于理解。 总之,Spring AOPSpring框架中实现面向切面编程的核心模块,通过在运行时动态生成代理对象,实现了对目标对象方法的拦截和增强。它通过将通用的横切关注点从业务逻辑中抽离出来,提高了代码的可维护性和可重用性。 ### 回答3: Spring AOP(Aspect-Oriented Programming)是Spring框架中的一个重要模块,用于实现面向切面编程的功能。它通过在不修改原有代码的情况下,将横切关注点(如日志记录、安全检查、事务管理等)从业务逻辑中分离出来,从而提高系统的可维护性和可重用性。 Spring AOP的核心原理是基于动态代理技术,通过在运行时动态生成代理对象来实现AOP功能。它主要由以下几个核心概念组成: 1. 切面(Aspect):是对一个特定横切关注点的抽象描述,它包含了一组通知(Advice)和一个切点(Pointcut)。通知定义了在切点处执行的具体操作,切点定义了在应用程序中哪些位置应该触发通知。 2. 连接点(Join point):是在程序运行过程中,符合切点定义的特定位置,如方法调用、异常抛出等。Spring AOP仅支持方法级别的切点。 3. 通知(Advice):是在连接点处执行的具体操作,包括前置通知(Before)、后置通知(After)、返回通知(AfterReturning)、异常通知(AfterThrowing)和环绕通知(Around)等。它们分别在连接点的不同位置执行,实现不同的横切关注点功能。 4. 切点表达式(Pointcut Expression):是一个表达式,用于匹配特定的切点位置。Spring AOP支持使用AspectJ风格的切点表达式语法。 Spring AOP的应用步骤如下: 1. 定义切面类,包含通知和切点的定义。 2. 配置切面,通过XML配置或基于注解的方式将切面配置到Spring容器中。 3. 定义目标类,即需要被代理的类。 4. 配置代理,通过XML配置或基于注解的方式将目标类与切面关联起来。 5. 启动Spring容器,自动完成代理的实例化和连接点的绑定。 6. 运行程序,当连接点满足切点定义时,代理会根据定义的通知类型执行相应的操作。 总之,Spring AOP是一种强大的横切关注点分离工具,它通过代理机制实现对目标类的增强,使得系统的关注点分离更加灵活和简单。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值