本文共 1473 字,大约阅读时间需要 4 分钟。
在初次使用logback的自定义配置文件完整的控制spring boot日志后,发现了一个无法忍受的问题,就是日志乱码。
控制台看到打印日志乱码如下:
而日志文件打开:
记事本打开
sublime打开
关于这个问题,分析如下:
1.打印的“进入Controller日志控制中心----》》》”字样可以看出,至少代码本身和IDE环境的编码方式没有任何的关系;
2.打印出来的日志是logback-spring.xml文件起作用之后,显示在控制台的,而日志文件打开后,看到 不同的文本编辑器打开是不一样的。
结论:
1.可以肯定,这个是logback-spring.xml自定义配置起作用之后导致的
2.日志文件中并不是不乱码,而是不同的编辑软件的默认编码方式是不一样的。所以才会有的乱码,有的并不乱码。
观察logback-spring.xml文件。可以看到:
解决办法:
所以,我们只需要将<charset>中的值设置为自己想要的编码方式即可
基本的完整的logback-spring.xml文件代码:【注意,file部分的charset依旧为GBK】
logback INFO 控制台-%d{yyyy-MM-dd HH:mm:ss} [%thread] %-5level %logger - %msg%n UTF-8 ${log.path} logback.%d{yyyy-MM-dd}.log 30 1GB 文件记录-%d{yyyy-MM-dd HH:mm:ss} [%thread] %-5level %logger{36} - %msg%n GBK
运行结果:
转载地址:http://ndenx.baihongyu.com/