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

本文介绍了如何通过AOP和自定义@Log注解,实现方法入参、返回值、描述及耗时的自动打印,避免手动添加日志代码,提高代码整洁性。示例中使用了Fastjson进行序列化,并给出了具体的配置、注解定义、切面实现以及测试案例。
摘要由CSDN通过智能技术生成

介绍

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

之前都是在方法的第一行手动打印 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
    评论
要实现 AOP 自定义注解获取实体入参,可以按照以下步骤进行: 1. 定义注解:定义一个注解,用于标记需要被 AOP 拦截的方法。 2. 编写切面:编写一个切面,用于拦截被注解标记的方法,并获取方法数。 3. 获取实体入参:在切面中获取方法数,通过反射的方式获得实体入参。 下面是一个示例代码,假设我们需要获取被 @LogAnnotation 注解标记的方法的实体入参: 定义注解: ```java @Target(ElementType.METHOD) @Retention(RetentionPolicy.RUNTIME) public @interface LogAnnotation { String value() default ""; } ``` 编写切面: ```java @Component @Aspect public class LogAspect { @Around("@annotation(com.example.demo.annotation.LogAnnotation)") public Object around(ProceedingJoinPoint pjp) throws Throwable { // 获取方法数 Object[] args = pjp.getArgs(); // 判断数是否为实体类 for (Object arg : args) { if (arg instanceof BaseEntity) { // 获取实体入参 BaseEntity entity = (BaseEntity) arg; // TODO: 处理实体入参 } } // 执行方法 Object result = pjp.proceed(); return result; } } ``` 在上面的代码中,我们使用 @Around 注解标记了 around 方法,并指定了切点表达式 @annotation(com.example.demo.annotation.LogAnnotation),表示拦截被 @LogAnnotation 注解标记的方法。在 around 方法中,通过 ProceedingJoinPoint 对象获取方法数,然后判断数是否为实体类,如果是实体类,则获取实体入参,进行处理。 注意,在获取实体入参时,我们使用了 instanceof 判断数是否为实体类,因此需要保证实体类继承了一个 BaseEntity 类或接口,否则无法判断数是否为实体类。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值