项目为什么引入log4j而不是logback代码
程序员文章站
2022-06-30 20:00:57
什么是slf4jslf4j,即简单日志门面(simple logging facade for java),不是具体的日志解决方案,它只服务于各种各样的日志系统。按照官方的说法,slf4j是一个用于日...
什么是slf4j
slf4j,即简单日志门面(simple logging facade for java),不是具体的日志解决方案,它只服务于各种各样的日志系统。按照官方的说法,slf4j是一个用于日志系统的简单facade,允许最终用户在部署其应用时使用其所希望的日志system。
上面已经介绍了slf4j,那么至于为什么使用它。slf4j可以看成是接口,那么既然是接口,实现在哪里呢?实现就是基于你自己的系统需要引入什么日志。我这里使用了log4j作为slf4j的实现。那么就可以通过slf4j来输出日志。
试想一下,如果你使用了第三方的类库,那么比如别人使用了java.util.logging.logger这个类库系统,那么你的项目使用的是log4j日志系统,你是不是要重新引入2种日志系统呢?那现在就有人为了解决这个问题,就提供了slf4j这个日志接口类库。你只要使用slf4j就可以了,至于你系统使用什么类库作为我的实现,我不管。那么这样问题就解决了,这也符合java的面向对象编程。
代码部分,由于sprintboot 默认使用logback,如果想用log4j, 需要排除掉logback的jar,引入log4j 的jar
看看依赖
<dependencies> <!--slf4j和log4j日志交换包--> <dependency> <groupid>org.slf4j</groupid> <artifactid>slf4j-log4j12</artifactid> </dependency> <!--log4j包--> <dependency> <groupid>log4j</groupid> <artifactid>log4j</artifactid> <version>1.2.17</version> </dependency> <dependency> <groupid>org.springframework.boot</groupid> <artifactid>spring-boot-starter-web</artifactid> <!--排除logback包 --> <exclusions> <exclusion> <groupid>ch.qos.logback</groupid> <artifactid>logback-classic</artifactid> </exclusion> <exclusion> <groupid>ch.qos.logback</groupid> <artifactid>logback-core</artifactid> </exclusion> </exclusions> </dependency> <dependency> <groupid>org.springframework.boot</groupid> <artifactid>spring-boot-starter-test</artifactid> <scope>test</scope> <exclusions> <exclusion> <groupid>org.junit.vintage</groupid> <artifactid>junit-vintage-engine</artifactid> </exclusion> </exclusions> </dependency> </dependencies>
测试,生效的是log4j:
如果还原依赖:
<dependencies> <dependency> <groupid>org.springframework.boot</groupid> <artifactid>spring-boot-starter-web</artifactid> </dependency> <dependency> <groupid>org.springframework.boot</groupid> <artifactid>spring-boot-starter-test</artifactid> <scope>test</scope> <exclusions> <exclusion> <groupid>org.junit.vintage</groupid> <artifactid>junit-vintage-engine</artifactid> </exclusion> </exclusions> </dependency> </dependencies>
测试结果,看到用的是logback:
反正是就要引入这些包, 但是slf4j-api已经在springboot-web里了。所以我的代码中没有再引入。
//slf4j包 <dependency> <groupid>org.slf4j</groupid> <artifactid>slf4j-api</artifactid> <version>1.8.0-beta2</version> </dependency> //slf4j和log4j日志交换包 <dependency> <groupid>org.slf4j</groupid> <artifactid>slf4j-log4j12</artifactid> <version>1.8.0-beta2</version> </dependency> //log4j包 <dependency> <groupid>log4j</groupid> <artifactid>log4j</artifactid> <version>1.2.17</version><dependency>
最后讲一下用intellij看依赖:
在pom.xml 鼠标右键
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
下一篇: mysql建表常用的sql语句汇总