SpringBoot2 中如何使用 Log4j2 动态记录日志并根据 API 接口路径保存到对应路径的文件?

springboot2 中如何使用 log4j2 动态记录日志并根据 api 接口路径保存到对应路径的文件?

springboot2 log4j2 如何动态记录日志,并将日志根据api接口路径,保存到对应路径的文件中?

这个问题可以通过使用 log4j2 的 routingappender 来实现。routingappender 允许根据指定条件将日志路由到不同的目的地。

如知AI笔记 如知AI笔记

如知笔记——支持markdown的在线笔记,支持ai智能写作、AI搜索,支持DeepseekR1满血大模型

如知AI笔记 27 查看详情 如知AI笔记

步骤:

在 log4j2-spring.xml 中配置 routingappender:

                                                                                                                %d{iso8601} [%t] %p %c{3} - %m%n                                                                                                                                                                                                                                                            %d{iso8601} [%t] %p %c{3} - %m%n                                                                                                                                                                                                                                                            %d{iso8601} [%t] %p %c{3} - %m%n                                                                                                                                                                                                                                

创建一个拦截器类,在请求处理前将接口路径动态写入到 threadcontext 中:

public class log4j2interceptor implements handlerinterceptor {        @override    public boolean prehandle(httpservletrequest request, httpservletresponse response, object handler) throws exception {                string routingkey = request.getrequesturi().substring(request.getcontextpath().length());        threadcontext.put("routingkey", routingkey);                return true;    }        @override    public void posthandle(httpservletrequest request, httpservletresponse response, object handler, modelandview modelandview) throws exception {        threadcontext.remove("routingkey");    }    }

注册拦截器:

@Configurationpublic class InterceptorConfig implements WebMvcConfigurer {    @Override    public void addInterceptors(InterceptorRegistry registry) {        InterceptorRegistration log4j2Registration = registry.addInterceptor(useLog4j2Inter());                log4j2Registration                    .addPathPatterns("/**");    }    @Bean    public Log4j2Interceptor useLog4j2Inter() {        return new Log4j2Interceptor();    }}

以上就是SpringBoot2 中如何使用 Log4j2 动态记录日志并根据 API 接口路径保存到对应路径的文件?的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/450063.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月7日 22:40:29
下一篇 2025年11月7日 22:46:12

相关推荐

发表回复

登录后才能评论
关注微信