aop 获取方法入参_利用 AOP 打印方法入参、返回值、描述、耗时

介绍

公司项目有需求想要打印方法的入参和返回值, 还要求打印方法的说明。

之前都是在方法的第一行手动打印 log, return 之前再打印返回值, 有多个返回点时需要出现重复代码, 有太多非业务代码显得凌乱。

后来采用 AOP 配置自定义 @Log 注解实现了此功能(主要是用于设置方法说明), 包括方法耗时统计。方法的入参和返回值都采用 fastjson 序列化。现贴出来, 一来给自己做个记录, 二来分享供大家参考指正。

依赖

com.alibaba

fastjson

org.aspectj

aspectjweaver

org.springframework

spring-context

org.slf4j

slf4j-api

注解

package com.ecej.esmart.core.annotation;

import java.lang.annotation.ElementType;

import java.lang.annotation.Retention;

import java.lang.annotation.RetentionPolicy;

import java.lang.annotation.Target;

/**

* Created by junbaor on 2017/5/12.

*/

@Target({ElementType.TYPE, ElementType.METHOD})

@Retention(RetentionPolicy.RUNTIME)

public @interface Log {

/**

* log 说明

*

* @return

*/

String value() default "";

/**

* 是否忽略,比如类上面加的有注解,类中某一个方法不想打印可以设置该属性为 true

*

* @return

*/

boolean ignore() default false;

}

实现

package com.ecej.esmart.core.common;

import com.alibaba.fastjson.JSONObject;

import com.alibaba.fastjson.serializer.SerializerFeature;

import com.ecej.esmart.core.annotation.Log;

import org.aspectj.lang.ProceedingJoinPoint;

import org.aspectj.lang.annotation.Around;

import org.aspectj.lang.annotation.Aspect;

import o

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值