工作防踩坑之-aspect打印接口参数

工作中用aspect打印了接口的出参、入参,踩了一些坑,故写出来记录一下
首先,要导入依赖

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-aop</artifactId>
        </dependency>

然后是aspect类

@Slf4j
@Aspect
@Component
public class ParamLogAspect {
	
	@Pointcut("execution(public * com.xxx.xx.*Controller.*.(..))")
	public void paramLog() {}
	// 方法一:用@Before + @AfterReturning
	@Before("paramLog()") 
	public void before(JoinPoint point) {
		String className = point.getTarget().getClass().getName();
		String methodName = point.getSignature().getName();
		Object[] args = point.getArgs();
		log.info("{}.{}()方法的入参是:{}", className, methodName, JSONObject.toJSONString(args));
	}

	@AfterReturning(pointcut = "paramLog()", return = "res")
	public void after(JoinPoint point, Object res) {
		String className = point.getTarget().getClass().getName();
		String methodName = point.getSignature().getName();
		// 注意,如果这里的返回值类型是Iterator,那么他会不停的调用next()方法,去获取下一个值,此时应避免打印这种出参
		log.info("{}.{}()方法的出参是:{}", className, methodName, JSONObject.toJSONString(res));
	}
	
	// 方法二:用@Around
	@Around("paramLog()")
	public Object around(ProceedingJoinPoint point) throws Throwable {
		String className = point.getTarget().getClass().getName();
		String methodName = point.getSignature().getName();
		Object[] args = point.getArgs();
		log.info("{}.{}()方法的入参是:{}", className, methodName, JSONObject.toJSONString(args));
		
		Object res = point.proceed();

		log.info("{}.{}()方法的出参是:{}", className, methodName, JSONObject.toJSONString(res));
		// 一定要返回res!(踩过这个坑)
		return res;
	}
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值