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