• 如何使用 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. }

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

  • 相关阅读:
    【AI视野·今日Robot 机器人论文速览 第五十一期】Tue, 10 Oct 2023
    Javascript核心技术的基础语法
    【学习笔记】字符串
    java.io.File类常用的方法
    逮到一个阿里10年老测试员,聊过之后收益良多...
    C#开发mvvm模式和mvc的区别
    P4727 [HNOI2009] 图的同构计数
    点云对齐/轨迹对齐方法及论文讲解
    LeetCode 0304. 二维区域和检索 - 矩阵不可变
    Leetcode2-两数相加代码详解
  • 原文地址:https://blog.csdn.net/allway2/article/details/127977951