项目为什么引入log4j而不是logback代码
作者:圣金巫灵 时间:2023-02-02 07:51:07
什么是slf4j
SLF4J,即简单日志门面(Simple Logging Facade for Java),不是具体的日志解决方案,它只服务于各种各样的日志系统。按照官方的说法,SLF4J是一个用于日志系统的简单Facade,允许最终用户在部署其应用时使用其所希望的日志System。
为什么使用slf4j
上面已经介绍了slf4j,那么至于为什么使用它。Slf4j可以看成是接口,那么既然是接口,实现在哪里呢?实现就是基于你自己的系统需要引入什么日志。我这里使用了log4j作为slf4j的实现。那么就可以通过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 鼠标右键
来源:https://www.cnblogs.com/dayanjing/p/13800105.html
标签:项目,log4j,logback
0
投稿
猜你喜欢
Android中使用GridView进行应用程序UI布局的教程
2022-03-19 15:18:06
Java安全框架——Shiro的使用详解(附springboot整合Shiro的demo)
2022-05-29 09:46:46
Android Retrofit原理深入探索
2023-09-06 02:47:15
Bean实例化之前修改BeanDefinition示例详解
2023-10-26 23:31:09
C#文件操作的简单实例
2021-12-14 16:50:40
Java中垃圾回收器GC对吞吐量的影响测试
2022-12-16 12:15:53
Android仿优酷圆形菜单学习笔记分享
2023-07-31 06:02:31
基于WPF实现控件轮廓跑马灯动画效果
2022-05-03 20:10:08
Java cookie和session会话技术介绍
2021-12-30 06:51:22
详解Java中Math.round()的取整规则
2022-10-20 14:22:01
VMware虚拟机下hadoop1.x的安装方法
2023-07-27 08:01:40
Android Volley图片加载功能详解
2023-11-19 08:01:41
C# 超高面试题收集整理
2022-01-20 17:28:59
Jpa Specification如何实现and和or同时使用查询
2023-10-17 20:49:38
Spring security登录过程逻辑详解
2022-09-04 19:58:20
Java封装、继承、多态三大特征的理解
2023-07-16 14:26:46
基于C# 生成Zip压缩包代码
2023-12-17 23:20:10
Windows下搭建Flutter开发环境
2023-11-06 01:32:52
Android Shader应用开发之霓虹闪烁文字效果
2022-09-11 16:43:20
c#调用vc写的ocx控件示例
2021-09-26 19:34:00