IDEA tomcat容器和log4j日志中文乱码的终极解决方案

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
原文作者:原则

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值