Feign日志切面

该博客介绍了如何使用AOP实现Feign客户端的日志切面。主要关注于请求和响应参数的记录,包括参数类型转换及日志输出。通过ThreadLocal存储请求信息,并在请求前后进行操作,提供详细的请求和响应日志,有助于调试和问题排查。
摘要由CSDN通过智能技术生成

import com.alibaba.fastjson.JSONObject;
import lombok.extern.slf4j.Slf4j;
import org.aspectj.lang.JoinPoint;
import org.aspectj.lang.ProceedingJoinPoint;
import org.aspectj.lang.annotation.*;
import org.aspectj.lang.reflect.MethodSignature;
import org.springframework.stereotype.Component;

import java.time.Duration;
import java.time.LocalDate;
import java.time.LocalDateTime;
import java.util.Date;
import java.util.HashMap;
import java.util.Map;

/**
 * Feign日志切面
 * @version 1.0
 */
@Aspect
@Component
@Slf4j
public class FeignLogAspect {

    private ThreadLocal<Map<String,Object>> feignContext = new ThreadLocal<>();

    private Object get(String key){
        if (feignContext.get() == null) {
            return null;
        }
        return feignContext.get().get(key);
    }

    private void set(String key, Object value){
        if (feignContext.get() == null) {
            feignContext.set(new HashMap<>(5));
        }
        feignContext.get().put(key, value);
    }

    private void remove() {
        feignContext.remove();
    }

    @Pointcut("execution(* com.gaara.demo.feign.*.*(*))")
    public void pointcut(){}


    @Before("pointcut()")
    public void doBefore(JoinPoint jp) {
        try {
            Object[] args = jp.getArgs();
            StringBuilder sb = new StringBuilder();
            if (args != null && args.length > 0) {
                if (args.length == 1) {
                    Object arg = args[0];
                    if (!(arg instanceof String || arg instanceof Integer || arg instanceof Long
                            || arg instanceof Boolean || arg instanceof Date || arg instanceof LocalDate
                            || arg instanceof Double || arg instanceof Float)) {
                        sb.append(JSONObject.toJSONString(arg));
                    } else {
                        sb.append("Param").append(0).append("=").append(arg.toString());
                    }
                } else {
                    for (int i = 0; i < args.length; i++) {
                        Object arg = args[i];
                        sb.append("Param").append(i).append("=").append(arg.toString());
                        if ( i < args.length -1) {
                            sb.append(",");
                        }
                    }
                }
            }
            log.info("请求参数:{}", sb.toString());
            // set("createdDate", LocalDateTime.now());
            // set("reqData", sb.toString());
        } catch (Exception ex) {
            log.warn("日志切面错误:", ex);
        }
    }


    @AfterReturning(returning = "ret", pointcut = "pointcut()")
    public void retLog(JoinPoint joinPoint, Object ret) {
        try {
            log.info("返回参数:{}", JSONObject.toJSONString(ret));
            //LocalDateTime createdDate = (LocalDateTime) get("createdDate");
            //LocalDateTime updatedDate = LocalDateTime.now();
            //Duration duration = Duration.between(createdDate, updatedDate);
            //long millis = duration.toMillis();
            //log.info("耗时:{}ms", millis);
        } catch (Exception ex) {
            log.warn("日志切面错误",ex );
        } finally {
            // 移除线程局部变量
            //remove();
        }
    }
}

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值