如何将Log4j彻底切换成logback

如何将Log4j彻底切换成logback?

之前有篇文章《彻底搞明白为什么日志框架依赖冲突了》介绍了同一项目中因为依赖了多个日志实现而导致的异常。log4j和logback都是日志实现,通常情况下,我们项目中都不会直接使用实现类,而是使用slf4j、jcl、log4j-api等日志facade。这样最大的好处就是,项目不会和某一日志框架绑定。

本篇将介绍如果把项目的日志框架切换成logback,切成其它的实现同理实现即可。

1、排除项目中所有的log4j、log4j-core相关的依赖。

这里推荐idea插件Maven helper工具,来查看和管理依赖。
在这里插入图片描述
在这个界面上可以查到项目中直接依赖和间接依赖的所有的log4j的jar,然后选中右键排除即可。

2、桥接其它日志框架到slf4j

如果某个jar破坏了“我们项目中都不会直接使用实现类”这个原则,直接使用了log4j里面的类,那怎么办?排掉项目就回报错,比如:

2021-12-29 14:50:12 ERROR c.q.b.d.c.GlobalDefaultExceptionHandler - Exception occurred: Handler dispatch failed; nested exception is java.lang.NoClassDefFoundError: org/apache/log4j/Level
org.springframework.web.util.NestedServletException: Handler dispatch failed; nested exception is java.lang.NoClassDefFoundError: org/apache/log4j/Level
	at org.springframework.web.servlet.DispatcherServlet.doDispatch(DispatcherServlet.java:1006)
	at org.springframework.web.servlet.DispatcherServlet.doService(DispatcherServlet.java:925)
	at org.springframework.web.servlet.FrameworkServlet.processRequest(FrameworkServlet.java:974)
	at org.springframework.web.servlet.FrameworkServlet.doGet(FrameworkServlet.java:866)
	at javax.servlet.http.HttpServlet.service(HttpServlet.java:503)
	at org.springframework.web.servlet.FrameworkServlet.service(FrameworkServlet.java:851)
	at javax.servlet.
  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值