测试服务器调用接口不会传递出乱码,而在本地服务器调用接口会传递出中文的乱码,所以我定位到是tomcat的问题
1.检查tomcat\conf\server.xml文件,发现已经设置了URIEncoding=“UTF-8”,所以排除是这块的原因
<Connector port="8080" protocol="HTTP/1.1"
connectionTimeout="20000"
URIEncoding="UTF-8"
redirectPort="8443" />
2.检查tomcat\bin\catalina.bat文件,找到set "JAVA_OPTS=%JAVA_OPTS% %JSSE_OPTS%"这段文字,改成set “JAVA_OPTS=%JAVA_OPTS% %JSSE_OPTS% -Dfile.encoding=UTF-8”,问题解决。
set "JAVA_OPTS=%JAVA_OPTS% %JSSE_OPTS% -Dfile.encoding=UTF-8"
3.问题延伸:修改了以上的配置后,发现IDEA的Output中,控制台打印的中文出现了乱码
进入Help -> Edit Custom VM Options,添加-Dfile.encoding=UTF-8这句话后,重启IDEA,发现控制台输出不再乱码
4.问题延伸:修改了步骤3的配置后,我发现虽然控制台输出不再乱码,但在IDEA的OutPut中,tomcat的日志打印出现了中文乱码(未出现乱码的跳过)
进入tomcat\conf\logging.properties,把java.util.logging.ConsoleHandler.encoding = GBK,改成java.util.logging.ConsoleHandler.encoding = UTF-8后,问题解决
5.总结(解决的问题)
1.GET/POST请求传递给三方接口的参数中文乱码
2.IDEA的OutPut出现控制台输出中文乱码
3.IDEA的OutPut出现tomcat日志打印乱码