解决springboot整合logback-spring.xml后控制台不输出debug级别的日志

今天我去配置项目的拦截器的时候,想在拦截器里面打印一些debug的日志信息,发现一直无法打印出来,而日志文件能够正常的记录,我就自己去测试了一下,发现了最终的问题所在。

首先我去检查了我日志文件中对于debug级别的日志处理,我发现没有任何问题

<!-- console -->
    <appender name="STDOUT" class="ch.qos.logback.core.ConsoleAppender">
        <encoder>
            <pattern>%d %level [%thread] %logger{10} [%file:%line] %msg%n</pattern>
            <charset>utf-8</charset>
        </encoder>
        <filter class="ch.qos.logback.classic.filter.ThresholdFilter">
            <level>debug</level>
        </filter>
    </appender>

然后就去写了一个测试类去测试

@SpringBootTest
public class LoggerTest {
       Logger logger = LoggerFactory.getLogger(LoggerTest.class);
     @Test
    void logTest1(){
        logger.debug("debug info");
        logger.warn("warn info");
        logger.error("error info");
    }
}

运行结果

spring boot项目启动控制台没有日志 springboot控制台不输出日志_配置文件

发现只打印了warn级别和error级别的日志,我就去看了一下我的配置文件,我发现我去声明包的日志级别时,声明错了,我的项目应该是在com.zky下,而我写成了com.zky.community

spring boot项目启动控制台没有日志 springboot控制台不输出日志_配置文件_02

修改后

spring boot项目启动控制台没有日志 springboot控制台不输出日志_spring_03

原因:由于我使用的是slf4j来作为日志处理,而slf4j的配置文件的包下的默认日志级别是info,低于info级别的信息都不会被打印(例如debug,trace),所以我们需要保证我们需要去debug所在类的日志级别是debug。

最终结果:成功打印!!!

spring boot项目启动控制台没有日志 springboot控制台不输出日志_配置文件_04