由于我之前安装过tomcat9的版本,同样经历过控制台乱码,发过9的帖子来记录解决问题,但是我今天重新配置tomcat8版本,发现8和9很多地方都不一样,本贴就详细记录一下解决idea运行tomcat8控制台乱码问题。并且补充一下老帖子不足之处。
解决idea执行tomcat9 Catalina log 乱码问题
问题描述:
idea运行tomcat8.5.27版本控制台输出乱码。
版本:
jdk1.8.0_172
IntelliJ IDEA 2019.3 3 (Ultimate Edition)
apache-tomcat-8.5.27
乱码: (由于控制台输出语句太多,这里我只截取开头和结尾)
Server:
Tomcat Catalina Log:
解决思路:
在老帖子中我配置好了tomcat9的logging.properties,在idea控制台完美解决。但我发现启动tomcat目录下\bin\startup.bat文件依旧乱码,因此推断是问题根本在于控制台输出格式和系统不一致。
因为apache-tomcat-8.5.27\conf\和tomcat-9.0.55\conf\目录中的logging.properties文件内容非完全相同,所以我并没有全部添加encoding编码,而是跟大多数帖子中一样,选择了添加java.util.logging.ConsoleHandler.encoding = UTF-8,其他保持默认。
在最后我经过反复配置才想到,因为在很多人安装idea时通常会改一些自己常用的配置,其中就包括设置UTF-8。而windows默认编码集为936(GBK),因此乱码。所以阿,乱码并不可怕,可怕的还是小白的我们无知罢了~
so,如果经常使用idea启动tomcat,那么只需要跟着idea一样设置tomcat的编码集为GTF-8就好了。
问题解决:
修改apache-tomcat-8.5.27\conf\logging.properties文件并保存,添加以下代码:
java.util.logging.ConsoleHandler.level = FINE
java.util.logging.ConsoleHandler.formatter = org.apache.juli.OneLineFormatter
java.util.logging.ConsoleHandler.encoding = UTF-8
如图:
重启idea中tomcat服务,有效解决:
其实到这步idea没有乱码就可以了~ ~
但是如果你跟我一样是个强迫症,那么欢迎你往下继续看:
并且恭喜你,因为我们的性格一样,所以下面的内容不光可以解决问题,还能get到新知识点!
问题描述:重启apache-tomcat-8.5.27\bin\startup.bat,乱码,继续解决
>>如果启动 apache-tomcat-8.5.27\bin\startup.bat 闪退请看帖子:Tomcat执行startup.bat出现闪退的可能原因及解决
开始一步一步解决吧,go:
右键tomcat属性可以看到,默认使用的是936,GBK
但是关于编码不匹配导致的乱码,相关的配置位置有很多,包括 context.xml,server.xml,logging.properties,IDEA上的配置,还有java虚拟机参数(-Dfile.encoding=UTF-8)等..
开始解决:
1、打开本机注册表
2、打开HKEY_CURRENT_USER — Console — 新建项 (如果有Tomcat直接打开找到CodePage就行,我这里没有,所以新建一个)
3、新建QWORD,命名CodePage,跟据自己电脑选择32/64位
4、右键修改 值为65001 基数为十进制,确定保存
ok,验收成果,配置文件GTF-8,Tomcat属性GBK
启动startup.bat: 未乱码,完美解决!
shutdown.bat关闭。
总结:
废话和步骤可能有点多,其实总的来说就是很多人在配置idea时候会默认配置UTF-8,而且我们的windows系统默认编码为936 (注:65001为UTF-8, 936为GBK),打开cmd窗口输出chcp查询:,那么同GBK情况下肯定不会乱码啦,,但是idea控制台配置UTF-8编码怎么可能不报错呢? 这里我也没用实际求证哈,我猜的。只能说用idea多保证idea不乱码就好了。