IDEA tomcat容器和log4j日志中文乱码的终极解决方案
首先描述下我遇到的问题
Eclipse没问题,idea问题如下。
项目启动的情况下:
1.log4j配置文件配置的编码为UTF-8,日志打印中文会乱码;
2.如果我将log4j中配置的编码改为GBK,日志打印中文正常;
项目未启动情况下:
1.log4j配置文件配置的编码为UTF-8,日志打印中文正常;
2.如果我将log4j中配置的编码改为GBK,日志打印中文乱码;
我推测这个可能与tomcat有关,于是试过很多方法(流下没有技术的眼泪),调试很多次,最后结果总结起来就是要么启动信息的中文乱码,要么日志打印乱码,内心一度奔溃(我承认我是菜鸟T_T)
终于在我找了很久之后看到了这篇文章,当看完这篇文章的时候,内心十分激动,更改之后的结果也完美解决了我的问题。
一、Tomcat容器下Conf文件夹
如果是GBK改为UTF-8
java.util.logging.ConsoleHandler.encoding = UTF-8
<Connector port="8080" protocol="HTTP/1.1"
connectionTimeout="20000"
redirectPort="8443" URIEncoding="UTF-8"/>
<!-- Define an AJP 1.3 Connector on port 8009 -->
<Connector port="8009" protocol="AJP/1.3"
redirectPort="8443" URIEncoding="UTF-8" />
二、网上很多说的改 IDEA安装目录bin下的idea.exe.vmoptions,idea64.exe.vmoptions两个文件,末尾加入 -Dfile.encoding=UTF-8
-Xms128m
-Xmx750m
-XX:ReservedCodeCacheSize=240m
-XX:+UseConcMarkSweepGC
-XX:SoftRefLRUPolicyMSPerMB=50
-ea
-XX:CICompilerCount=2
-Dsun.io.useCanonPrefixCache=false
-Djava.net.preferIPv4Stack=true
-Djdk.http.auth.tunneling.disabledSchemes=""
-XX:+HeapDumpOnOutOfMemoryError
-XX:-OmitStackTraceInFastThrow
-Djdk.attach.allowAttachSelf=true
-Dkotlinx.coroutines.debug=off
-Djdk.module.illegalAccess.silent=true
#末尾加入
-Dfile.encoding=UTF-8
在IDEA2019.3过后不生效!!!!!
在idea里面改才能生效,在工具栏help -》 Edit Custom VM Options,加上
-Dfile.encoding=UTF-8
三、启动项参数里面加入 -Dfile.encoding=UTF-8
转载原文链接: https://www.cnblogs.com/yuanzessrs/p/12100691.html
原文作者:原则