要作日志操作,先需配置依赖:
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-logging</artifactId>
<optional>true</optional>
</dependency>
然后简单的写一个打印日志的单元测试类:
import org.junit.Test;
//import org.junit.platform.commons.logging.Logger;
//import org.junit.platform.commons.logging.LoggerFactory;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.junit.runner.RunWith;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.test.context.junit4.SpringRunner;
@RunWith(SpringRunner.class)
@SpringBootTest
public class LoggerTests {
Logger logger= LoggerFactory.getLogger(getClass());
@Test
public void contextLoads(){
//System.out.println("println test...");
logger.trace("logger.trace test...");
logger.debug("logger.debug test...");
logger.info("logger.info test...");
logger.warn("logger.warn test...");
logger.error("logger.error test...");
}
}
此时直接运行测试,控制台是可以看到 logger.info("logger.info test..."); logger.warn("logger.warn test..."); logger.error("logger.error test..."); 这三个方法的输出结果的。(备注:默认不配置时,控制台输出的优先级是从logger.info开启的,所以trace和debug看不到。要想全看到五个,在application.properties文件中使用logging.level.com.xxxx=trace来实现) 到这里,可能你会想到它是不是会自动保存成了日志文件在硬盘中吧。当然答案是否定的。 因为默认是不开启写文件的,需要配置指定路径文件才会写。那么,可以这么配:在application.properties文件中,写上:
logging.file.name=testlog.log
然后,运行测试,会自动生成了testlog.log文件在项目下的根目录中,并且文件中会记录了控制台输出的日志。 经验:如果你是用过一些旧版本,配置时可能会用
logging.file=testlog.log
来配置,这样会发现没有日志文件产生出来,且没达到预期效果也没有报错。而需将logging.file改成logging.file.name才可以完成。
解决思路:不同的语言、框架、应用版本,如发现明明觉得所学的语法正确,但运行效果就是不达到,那么可能是版本升级后,原语法与新语法不同引起,需要注意查证正确用法再使用。
吐一吐心声:底层开发人员对底层框架的升级,或为了一些完美,或是考虑不周的改动,会给应用开发人员带来多些坑要填了。所以,底层的,公共的、基础的程序版本的开发与升级,都需三思而后行,要为使用者多着想一下,多综合考量才动。且最好是一开始就多进行命名规则规范设计,避免或减少后期命名的改动升级。