AOP实现日志打印方法入参出参

AOP术语

1、通知(Advise)
通知 执行顺序
前置通知(Before) 在目标方法被调用之前调用通知功能
后置通知(After) 在目标方法完成之后调用通知,此时不会关心方法的输出是什么
返回通知(After-returning) 在目标方法成功执行之后调用通知
异常通知(After-throwing) 在目标方法抛出异常后调用通知
环绕通知(Around) 通知包裹了被通知的方法,在被通知的方法调用之前和之后执行自定义的行为
2、连接点(JoinPoint)

连接点是在应用执行过程中能够插入切面的一个点。

3、切点(PointCut)

一个切面并不需要通知应用的所有连接点,切点有助于缩小切面所通知的连接点范围。如果说通知定义了切面的“什么”和“何时”的话,那么切点就定义了“何处”。因此,切点其实就是定义了需要执行在哪些连接点上执行通知。

4、切面(Aspect)

切面是通知和切点的结合。通知和切点共同定义了切面的全部内容——它是什么,在何时和在何处完成其功能。

5、引入(Introduction)

引入允许我们向现有的类添加新方法或属性。

6、织入(Weaving)

织入是把切面应用到目标对象并创建新的代理对象的过程。切面在指定的连接点被织入到目标对象中。在目标对象的生命周期中有很多个点可以进行织入。

自定义接口

我们需要通过自定义接口来指定需要打印入参出参的方法。
value()是我们输出日志时的标识,默认为""
ignore()我们可以用来设置注解是否要被忽略,默认为false
import java.lang.annotation.*;

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

    String value() default "";

    boolean ignore() default false;
}

定义切面

我们这里用到了@Around 环绕通知,能够在方法调用的前后执行这串代码逻辑。

@Pointcut指定切点,这里通过指定带有@Log注解的方法/类为切点。

通过反射获取到方法名、入参、出参。
import com.xxx.utils.JsonUtils;
import org.apache.log4j.Logger;
import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.annotation.*;
import org
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值