IDEA控制台乱码终极解决方案

1. 问题描述

  由于本机的IDEA 2019.1出现了无法连接插件商店和Spring Boot模板的问题,就重装了了最新的IDEA 2019.2.4版本,使用了一段时间以后,没有改任何的配置,控制台的中文就莫名其妙的开始乱码。使用了网上的各种办法,还是没有解决。

2. 问题的原因

  由于已经试了所有的方法也没能解决,我看到别人说可能是因为IDEA在安装目录和项目的缓存目录有两份环境配置,因为如果是项目缓存配置那么即使修改IDEA安装目录的配置也无济于事,缓存目录配置依旧无法改变,所以乱码依旧。
  根据这个思路,我开始测试到底是哪个地方出现了问题。首先,因为使用了Tomcat,所以可能是Tomcat使用了GBK而IDEA用了UTF-8导致的乱码,后来添加了程序内控制台输出也乱码,所以判定应该不只是Tomcat的问题,而且由于用的是Spring Boot,所以内置的Tomcat配置也不好修改。之后我突发奇想,如果我重新创建一个项目看看会不会乱码,于是用模板创建了一个Spring Boot项目,测试以后发现不管是Tomcat还是程序内输出到控制台,都没有乱码,我已经确定了就是因为因为缓存配置导致的。

3. 解决办法

  既然已经知道了问题的原因,解决的办法就有了,清除缓存就可以了。
  提示:在操作以下操作之前,请确保IDEA的设置正确,否则乱码可能会依旧存在。
  在IDEA项目中,点击左上角的File-Invalidate Caches / Restart。

弹出警示框,选择 Invalidate and Restart。

点击按钮之后,IDEA会自动关闭并重启,如果之前项目很多很大,那么缓存的重建速度将会比较慢。
启动项目,发现控制台不管是Tomcat输出还是程序输出文本都正常了。

4. 其他解决办法

这些方法就是网友提供的方法,如果实在解决不了,要么就当没看见,要么重装IDEA。

  1. 本地Tomcat问题
      如果是使用本机的Tomcat,需要修改Tomcat的server.xml文件。打开Tomcat的安装目录,找到conf目录下的server.xml文件并打开。找到 protocol="HTTP/1.1" 的标签,添加URIEncoding="UTF-8",效果如下。

      在同目录下找到 logging.properties 文件,使用文本编辑器打开。找到 "java.util.logging.ConsoleHandler.encoding",将值修改为 "UTF-8"。保存并重启Tomcat即可。也可以在IDEA里设置,不过更换项目还需要再配置,不方便。
      在项目主页最上面,找到 "Run",选择 "Edit Configurations..."。点开左侧"Templates",找到"Tomcat Server"-"Local"。在"VM options"中输入-Dfile.encoding=UTF-8,选择Apply保存,重启Tomcat即可。
  2. Spring内置Tomcat问题
    打开项目的 pom.xml ,在<build>中添加plugin,重启项目即可。
    <build>
    	<plugins>
    		<plugin>
    			<groupId>org.springframework.boot</groupId>
    			<artifactId>spring-boot-maven-plugin</artifactId>
    			<version>2.1.7.RELEASE</version>
    			<configuration>
    				<jvmArguments>-Dfile.encoding=UTF-8</jvmArguments>
    			</configuration>
    		</plugin>
    	</plugins>
    </build>
    
  3. IDEA配置问题
      打开IDEA安装目录下的bin文件夹,找到两个配置文件:idea.exe.vmoptions和idea64.exe.vmoptions。用文本编辑器打开这两个文件,分别在最后一行添加-Dfile.encoding=UTF-8。保存并重启IDEA即可。
  4. IDEA字符集设置问题
      打开IDEA的Settings设置界面,找到 Editor-File Encodings。将三个下拉栏都设置为"UTF-8",保存并重启IDEA。
posted @ 2019-12-08 22:57  苍凉温暖  阅读(3148)  评论(0编辑  收藏  举报