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

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

  • 相关阅读:
    关于在 Linux 下多个不相干的进程互斥访问同一片共享内存的问题
    排列组合【C语言】
    Spring与Docker:如何容器化你的Spring应用
    C++ 时间函数整理详解
    SpringBoot线上项目隐藏Swagger接口文档
    iOS 18 为 iPhone 15 机型引入了更多充电限制选项
    Linux 内核镜像分析
    node 之 express 框架(初级)
    【Django】聚合查询——聚合和其他 QuerySet 子句(filter() 、 exclude()、order_by()、values())
    Linux权限管理(用户+文件)
  • 原文地址:https://blog.csdn.net/allway2/article/details/127977951