gpt4 book ai didi

java - Spring Boot嵌入式tomcat将日志附加到每个tomcat请求

转载 作者:行者123 更新时间:2023-12-02 03:18:52 25 4
gpt4 key购买 nike

我使用的是 Spring Boot 版本 1.3.3。带有嵌入式tomcat。

对于每个网络请求,我想知道如何拦截网络请求并执行一些自定义代码,然后继续处理请求。

我的预感是我会重写一些默认的 servlet bean 或方法?我对此了解不多。

所以要把问题具体化。对于每个网络请求,我将如何执行以下代码

@Override  
public void someGenericWebParentRequest(Servlet servletRequest){
log.info("custom log called");
MDC.put("host-name", System.getenv("HOSTNAME")); // kibana hostname filter added

// whatever code you fancy etc :-)

return servletRequest; // continues onto web target controller
}

最佳答案

您可以使用Servlet Filter并在doFilter()中添加拦截请求。要将其添加到 Spring Context 中,请添加 @Component。

请参阅此示例。

@Component
public class SecurityFilter implements Filter{
@Override
public void init(FilterConfig filterConfig) throws ServletException {

}

@Override
public void doFilter(ServletRequest request, ServletResponse response, FilterChain chain) throws IOException, ServletException {
//you can intercept request and response here
System.out.println("###### security filter ");
chain.doFilter(request, response);
}

@Override
public void destroy() {

}
}

关于java - Spring Boot嵌入式tomcat将日志附加到每个tomcat请求,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39902448/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com