广告
返回顶部
首页 > 资讯 > 精选 >feign怎么打印出http请求
  • 318
分享到

feign怎么打印出http请求

2023-07-02 10:07:03 318人浏览 薄情痞子
摘要

这篇文章主要讲解了“feign怎么打印出Http请求”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“feign怎么打印出http请求”吧!feign打印出http请求用openfign依赖需要

这篇文章主要讲解了“feign怎么打印出Http请求”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“feign怎么打印出http请求”吧!

feign打印出http请求

用openfign依赖需要将请求的方法中的http请求打印出来

需要做如下两步:

1.记录请求和响应的头文件

正文和元数据的日志,需要在配置文件指出需要打印日志的类

 @Bean    Logger.Level feignLoggerLevel() {        return Logger.Level.FULL;    }

2.在配置文件中配置对应的包

logging:  level:    com.report.service.analysis.fegin.AdminServiceClient: debug

这样就会生效了,如下:

ms] ---> END HTTP (0-byte body)
2021-01-14 10:57:34.525 [http-NIO-8080-exec-1] DEBUG c.n.s.r.service.analysis.fegin.AdminServiceClient - TID: N/A - [ServiceClient#getDealerItemListByParams] <--- HTTP/1.1 200 (98ms)
2021-01-14 10:57:34.525 [http-nio-8080-exec-1] DEBUG c.n.s.r.service.analysis.fegin.AdminServiceClient - TID: N/A - [ServiceClient#getDealerItemListByParams] connection: keep-alive
2021-01-14 10:57:34.525 [http-nio-8080-exec-1] DEBUG c.n.s.r.service.analysis.fegin.AdminServiceClient - TID: N/A - [ServiceClient#getDealerItemListByParams] content-type: application/JSON
2021-01-14 10:57:34.525 [http-nio-8080-exec-1] DEBUG c.n.s.r.service.analysis.fegin.AdminServiceClient - TID: N/A - [ServiceClient#getDealerItemListByParams] date: Thu, 14 Jan 2021 02:57:34 GMT
2021-01-14 10:57:34.525 [http-nio-8080-exec-1] DEBUG c.n.s.r.service.analysis.fegin.AdminServiceClient - TID: N/A - [ServiceClient#getDealerItemListByParams] server: Nginx/1.19.0
2021-01-14 10:57:34.526 [http-nio-8080-exec-1] DEBUG c.n.s.r.service.analysis.fegin.AdminServiceClient - TID: N/A - ServiceClient#getDealerItemListByParams] transfer-encoding: chunked
2021-01-14 10:57:34.526 [http-nio-8080-exec-1] DEBUG c.n.s.r.service.analysis.fegin.AdminServiceClient - TID: N/A - [ServiceClient#getDealerItemListByParams] vary: Accept-Encoding
2021-01-14 10:57:34.526 [http-nio-8080-exec-1] DEBUG c.n.s.r.service.analysis.fegin.AdminServiceClient - TID: N/A - [ServiceClient#getDealerItemListByParams] 
2021-01-14 10:57:34.528 [http-nio-8080-exec-1] DEBUG c.n.s.r.service.analysis.fegin.AdminServiceClient - TID: N/A - [ServiceClient#getDealerItemListByParams] {"code":"000000","description":"SUCCESS","data":
2021-01-14 10:57:34.528 [http-nio-8080-exec-1] DEBUG c.n.s.r.service.analysis.fegin.AdminServiceClient - TID: N/A - [ServiceClient#getDealerItemListByParams] <--- END HTTP (2692-byte body)

feign请求日志统一打印

@Slf4jpublic class FeignLogger extends feign.Logger {    static ThreadLocal<Map<String, String>> loGContext = new ThreadLocal();    static String PATH = "path";    static String METHOD = "method";    static String REQUEST_BODY = "body";    static String ELAPSED_TIME = "耗时";    static String ELAPSED_TIME_UNIT = "毫秒";    static String FEIGN_INVOKE_LOGGER = "feign 接口调用";    @Override    protected void logRequest(String configKey, Level logLevel, Request request) {        Map<String, String> logMap = new HashMap<>(3);        logMap.put(PATH, request.url());        logMap.put(METHOD, request.method());        logMap.put(REQUEST_BODY, request.body() == null ? null :                request.charset() == null ? null : new String(request.body(), request.charset()));        logContext.set(logMap);    }    @Override    protected Response logAndRebufferResponse(            String configKey, Level logLevel, Response response, long elapsedTime) throws IOException {        Map<String, String> requetParam = logContext.get();        StringBuilder stringBuilder = new StringBuilder();        stringBuilder                .append(FEIGN_INVOKE_LOGGER).append(" ")                .append(requetParam.get(METHOD)).append(" ")                .append(response.status()).append(" ")                .append(requetParam.get(PATH)).append(" ")                .append(ELAPSED_TIME).append(elapsedTime).append(ELAPSED_TIME_UNIT);        if (requetParam.get(REQUEST_BODY) != null) {            stringBuilder.append(" 请求入参:").append(requetParam.get(REQUEST_BODY));        }        logContext.remove();        // 返回参数        if (response.body() != null && !(response.status() == 204 || response.status() == 205)) {            byte[] bodyData = Util.toByteArray(response.body().asInputStream());            if (bodyData.length > 0) {                String responseBody = decodeOrDefault(bodyData, UTF_8, "Binary data");                stringBuilder                        .append(" 返回值:")                        .append(responseBody.replaceAll("\\s*|\t|\r|\n", ""));            }            log.info(stringBuilder.toString());            return response.toBuilder().body(bodyData).build();        }        log.info(stringBuilder.toString());        return response;    }    protected IOException logIOException(String configKey, Level logLevel, IOException ioe, long elapsedTime) {        Map<String, String> requetParam = logContext.get();        StringBuilder stringBuilder = new StringBuilder();        stringBuilder                .append(FEIGN_INVOKE_LOGGER).append(" ")                .append(requetParam.get(METHOD)).append(" ")                .append(ioe.getClass().getSimpleName()).append(" ")                .append(requetParam.get(PATH)).append(" ")                .append(ELAPSED_TIME).append(elapsedTime).append(ELAPSED_TIME_UNIT);;        if (requetParam.get(REQUEST_BODY) != null) {            stringBuilder.append(" 请求入参:").append(requetParam.get(REQUEST_BODY));        }        log.warn(stringBuilder.toString());        logContext.remove();        return ioe;    }    @Override    protected void log(String configKey, String fORMat, Object... args) {        if (log.isInfoEnabled()) {            log.info(String.format(methodTag(configKey) + format, args));        }    }}

感谢各位的阅读,以上就是“feign怎么打印出http请求”的内容了,经过本文的学习后,相信大家对feign怎么打印出http请求这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

--结束END--

本文标题: feign怎么打印出http请求

本文链接: https://www.lsjlt.com/news/341245.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • feign怎么打印出http请求
    这篇文章主要讲解了“feign怎么打印出http请求”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“feign怎么打印出http请求”吧!feign打印出http请求用openfign依赖需要...
    99+
    2023-07-02
  • feign如何打印出http请求
    目录feign打印出http请求1.记录请求和响应的头文件2.在配置文件中配置对应的包feign请求日志统一打印feign打印出http请求 用openfign依赖需要将请求的方法中...
    99+
    2022-11-13
  • SpringCloud怎么利用Feign访问外部http请求
    这篇文章主要介绍了SpringCloud怎么利用Feign访问外部http请求的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇SpringCloud怎么利用Feign访问外部http请求文章都会有所收获,下面我们...
    99+
    2023-06-29
  • JavaScript中怎么发出HTTP请求
    这篇文章给大家介绍JavaScript中怎么发出HTTP请求,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。XMLHttpRequestXMLHttpRequest对象可用于从Web服务...
    99+
    2022-10-19
  • 如何使用golang中的net/http/httputil.DumpRequest函数打印HTTP请求信息
    如何使用golang中的net/http/httputil.DumpRequest函数打印HTTP请求信息概述:在Golang中,可以使用net/http包提供的httputil.DumpRequest函数来打印HTTP请求信息。这个函数可...
    99+
    2023-11-18
    net/http 关键词:Golang httputilDumpRequest
  • ASP.NET Core怎么使用IHttpClientFactory发出HTTP请求
    今天小编给大家分享一下ASP.NET Core怎么使用IHttpClientFactory发出HTTP请求的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章...
    99+
    2023-06-29
  • C# winform请求http怎么实现
    本篇内容主要讲解“C# winform请求http怎么实现”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“C# winform请求http怎么实现”吧!一:.Net中有两个类 ...
    99+
    2023-07-02
  • php怎么设置http请求体
    在PHP中,可以使用以下两种方法设置HTTP请求体:1. 使用`file_get_contents()`函数发送POST请求,并设置...
    99+
    2023-08-15
    php
  • Android怎么使用Coroutine + Retrofit打造简单的HTTP请求库
    这篇文章主要介绍了Android怎么使用Coroutine + Retrofit打造简单的HTTP请求库,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。基于 kotlin/co...
    99+
    2023-06-14
  • Win10添加网络打印机一打印出就出错该怎么办
    近期有的有客户发觉Win10添加网络打印机打印出的过程中会提醒出错,这也是复印机相关服务发生了不正确,只要将相关服务重新启动就可以解决困难,可是许多客户不清楚怎么解决,下边传授给大伙儿详细的解决方案,期待可以幫助大伙儿。Win10添加网络打...
    99+
    2023-07-15
  • Python Http发送请求怎么实现
    本篇内容介绍了“Python Http发送请求怎么实现”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!浅析requests在不借助其...
    99+
    2023-07-02
  • windows打印机正在打印但是打不出来怎么解决
    这篇文章主要介绍“windows打印机正在打印但是打不出来怎么解决”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“windows打印机正在打印但是打不出来怎么解决”文章能帮助大家解决问题。解决方法:一...
    99+
    2023-07-02
  • http请求怎么在spring boot中使用
    今天就跟大家聊聊有关http请求怎么在spring boot中使用,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。首先是经过封装:一:初始化httpclientprivate ...
    99+
    2023-05-30
    springboot http
  • nodejs中怎么实现一个http请求
    nodejs中怎么实现一个http请求,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。nodejs http请求相关总结通过no...
    99+
    2022-10-19
  • Qt怎么实现HTTP的Get/Post请求
    本文小编为大家详细介绍“Qt怎么实现HTTP的Get/Post请求”,内容详细,步骤清晰,细节处理妥当,希望这篇“Qt怎么实现HTTP的Get/Post请求”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。借助Qt的...
    99+
    2023-06-30
  • Netty4之怎么实现HTTP请求、响应
    本文小编为大家详细介绍“Netty4之怎么实现HTTP请求、响应”,内容详细,步骤清晰,细节处理妥当,希望这篇“Netty4之怎么实现HTTP请求、响应”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。1.Netty...
    99+
    2023-07-05
  • Python socket怎么解析HTTP请求内容
    本篇内容主要讲解“Python socket怎么解析HTTP请求内容”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Python socket怎么解析HTTP请求内容”吧!so...
    99+
    2023-06-29
  • php 打印出乱码该怎么办
    php 打印出乱码该怎么办,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。php打印出来乱码的解决办法:1、打开相应的PHP代码文件;2、在代码中添加“header("...
    99+
    2023-06-22
  • php 打印出来乱码怎么办
    本文操作环境:Windows7系统,PHP7.1版,Dell G3电脑。php 打印出来乱码怎么办php打印中文乱码php文档的文本格式都设置成 utf-8 格式在代码中添加header("content-type:text/ht...
    99+
    2020-09-14
    php 乱码
  • 怎么在java中输出打印流
    这篇文章给大家介绍怎么在java中输出打印流,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。Java的特点有哪些Java的特点有哪些1.Java语言作为静态面向对象编程语言的代表,实现了面向对象理论,允许程序员以优雅的思...
    99+
    2023-06-14
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作