springboot2 log4j2 如何动态记录日志,并将日志根据api接口路径,保存到对应路径的文件中?
这个问题可以通过使用 log4j2 的 routingappender 来实现。routingappender 允许根据指定条件将日志路由到不同的目的地。
步骤:
在 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 接口路径保存到对应路径的文件?的详细内容,更多请关注【创想鸟】其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。
发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2609359.html