项目为什么引入log4j而不是logback代码

网友投稿 746 2023-03-18

项目为什么引入log4j而不是logback代码

项目为什么引入log4j而不是logback代码

什么是slf4j

SLF4J,即简单日志门面(Simple Logging Facade for java),不是具体的日志解决方案,它只服务于各种各样的日志系统。按照官方的说法,SLF4J是一个用于日志系统的简单Facade,允许最终用户在部署其应用时使用其所希望的日志System。

为什么使用slf4j

上面已经介绍了slf4j,那么至于为什么使用它。Slf4j可GJaklzk以看成是接口,那么既然是接口,实现在哪里呢?实现就是基于你自己的系统需要引入什么日志。我这里使用了log4j作为slf4j的实现。那么就可以通过slf4j来输出日志。

slf4j的解耦

试想一下,如果你使用了第三方的类库,那么比如别人使用了java.util.logging.Logger这个类库系统,那么你的项目使用的是log4j日志系统,你是不是要重新引入2种日志系统呢?那现在就有人为了解决这个问题,就提供了slf4j这个日志接口类库。你只要使用slf4j就可以了,至于你系统使用什么类库作为我的实现,我不管。那么这样问题就解决了,这也符合java的面向对象编程。

代码部分,由于sprintboot 默认使用logback,如果想用log4j, 需要排除掉logback的jar,引入log4j 的jar

看看依赖

org.slf4j

slf4j-log4j12

log4j

log4j

1.2http://.17

org.springframework.boot

spring-boot-starter-web

ch.qos.logback

logback-classic

ch.qos.logback

logback-core

org.springframework.boot

spring-boot-starter-test

test

org.junit.vintage

junit-vintage-engine

测试,生效的是log4j:

如果还原依赖:

org.springframework.boot

spring-boot-starter-web

org.springframework.boot

spring-boot-starter-test

test

org.junit.vintage

junit-vintage-engine

测试结果,看到用的是logback:

反正是就要引入这些包, 但是slf4j-api已经在springboot-web里了。所以我的代码中没有再引入。

//slf4j包

org.slf4j

slf4j-api

1.8.0-beta2

//slf4j和log4j日志交换包

org.slf4j

slf4j-log4j12

1.8.0-beta2

//log4j包

log4j

log4j

1.2.17

最后讲一下用intellij看依赖:

在pom.xml 鼠标右键

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:微信小程序跳转到另一个小程序(微信小程序跳转到另一个小程序后关闭小程序)
下一篇:基于IDEA创建SpringMVC项目流程图解
相关文章

 发表评论

暂时没有评论,来抢沙发吧~