springcloud 拦截OpenFiegn请求日志打印

复制代码
import feign.RequestInterceptor;
import feign.RequestTemplate;
import feign.Target;
import feign.Target.HardCodedTarget;
import lombok.extern.slf4j.Slf4j;

import java.nio.charset.Charset;

@Slf4j
public class CustomerFeignRequestInterceptor implements RequestInterceptor {

    @Override
    public void apply(RequestTemplate template) {
        String url = template.url();
        Target<?> target = template.feignTarget();
        if (target instanceof HardCodedTarget) {
            HardCodedTarget hardCodedTarget = (HardCodedTarget) target;
            url = hardCodedTarget.url() + url;
        }
        String method = template.method();
        Charset charset = template.requestCharset();
        byte[] body = template.body();
        if (body == null) {
            body = "null".getBytes(charset);
        }
        log.info("\r\n{} {}\r\n{}", method, url, new String(body, charset));
    }
}
复制代码

其他项目中,将这个工具类交由Spring管理

    @Bean
    public CustomerFeignRequestInterceptor customerFeignRequestInterceptor() {
        return new CustomerFeignRequestInterceptor();
    }

 

posted @   陈彦斌  阅读(215)  评论(0编辑  收藏  举报
编辑推荐:
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?
历史上的今天:
2020-07-08 Mybatis模糊查询
2019-07-08 反射实体类拼接SQL语句
2019-07-08 JQuery Easy UI 1.7官网最新版附1.7API
点击右上角即可分享
微信分享提示
主题色彩