• 如何使用 CommonsRequestLoggingFilter 在 Spring 引导中跟踪 HTTP 请求


    本教程展示了如何使用CommonsRequestLoggingFilter 跟踪传入的 HTTP 请求。

    有几个选项可以跟踪Spring Boot 2.x应用程序的传入HTTP 请求。最简单的选择之一是使用CommonsRequestLoggingFilter它可以作为 Bean 添加到任何配置类中。请参阅以下示例:

    1. package com.example.testrest;
    2. import org.springframework.context.annotation.Bean;
    3. import org.springframework.context.annotation.Configuration;
    4. import org.springframework.web.filter.CommonsRequestLoggingFilter;
    5. @Configuration
    6. public class RequestLoggerFilter {
    7. @Bean
    8. public CommonsRequestLoggingFilter logFilter() {
    9. CommonsRequestLoggingFilter filter = new CommonsRequestLoggingFilter();
    10. filter.setIncludeQueryString(true);
    11. filter.setIncludePayload(true);
    12. filter.setMaxPayloadLength(10000);
    13. filter.setIncludeHeaders(false);
    14. filter.setAfterMessagePrefix("REQUEST DATA : ");
    15. return filter;
    16. }
    17. }

    您还需要在 application.properties 文件中设置 CommonsRequestLoggingFilter 的日志记录级别:

    logging.level.org.springframework.web.filter.CommonsRequestLoggingFilter=DEBUG 

    或者作为替代方案,在登录中.xml:

    1. "1.0" encoding="UTF-8"?><logger name="org.springframework.web.filter.CommonsRequestLoggingFilter">
    2. <level value="DEBUG"/>
    3. logger>

    添加后,您将能够在 Spring 引导控制台中看到传入的请求:

    2020-04-09 15:53:06.554 DEBUG 13536 --- [nio-8080-exec-1] o.s.w.f.CommonsRequestLoggingFilter      : Before request [uri=/list] 2020-04-09 15:53:06.630 DEBUG 13536 --- [nio-8080-exec-1] o.s.w.f.CommonsRequestLoggingFilter      : REQUEST DATA : uri=/list] 
    

    另一方面,如果要以流的形式接收HTTP请求,可以通过扩展HandlerInterceptorAdapter类来实现:

    1. @Component public class CustomHandlerInterceptorAdapter extends HandlerInterceptorAdapter {
    2. @Override public boolean preHandle(HttpServletRequest request, HttpServletResponse response, Object handler) {
    3. ServletRequest servletRequest = new ContentCachingRequestWrapper(request);
    4. servletRequest.getParameterMap();
    5. // Read inputStream and log it
    6. return true;
    7. }
    8. }

    请注意,当您处理输入流时,您不能将它们读取两次!

  • 相关阅读:
    2022年湖北省制造业单项冠军奖励标准以及申报条件,企业(产品)培育认定
    Vim 笔记
    按文件类型自动分类文件的快速方法
    【必会篇】日常测试工作中,有哪些必须知道的 SQL 语句?
    7. img 的 srcset 属性的作用?
    【Android】性能优化之内存、网络、布局、卡顿、安装包、启动速度优化
    百日刷题计划 ———— DAY2
    【磁盘】为什么文件大小很小,占用空间很大?
    Spring Boot 2.x系列【17】功能篇之JSON
    Java 将Map转成Json
  • 原文地址:https://blog.csdn.net/allway2/article/details/127977951