前言
事情的起因是这样的,当时我用了阿里云osssdk里的代码下载文件,如下
ossClient.getObject(new GetObjectRequest(bucketName, objectName), new File(pathName));
,开始一切顺利,直到部署正式环境后,用了一段时间报了个错,而这个错误提示里面的中文字符乱码了,不止jsp页面里的提示中文乱码,连windows控制台里面的system.out.println打印的也是中文乱码。然而,开发环境一切正常,页面错误提示里和开发工具控制台的中文都正常显示,并没有乱码。为了搞清楚,开始了两天的尝试。
解决过程
经过一番折腾,我在开发环境还原了导致乱码的配置,其实就是把Encoding变成GBK就行了
改完后,用这行代码可以知道当前环境的编码是什么
System.out.println("Default Charset=" + Charset.defaultCharset());
为什么会这样呢,我调试了下oss的源码 ,发现osssdk里面都是以utf8请求和接收的(就算改也改不动^_^)那就是说,当前的编码环境必须改成utf8的,好吧那就改吧
网上一通找
首先要改变jvm的编码,在catalina.bat里加上
set JAVA_OPTS=%JAVA_OPTS% -Dfile.encoding=UTF-8
然后运行上上条代码打印发现当前环境的编码已经变成utf8了
重启启动tomcat,发现网页里面的报错提示信息里面中文已经不乱码了,但是windows控制台里面system.out.printlin里中文还是乱码,而且里面的其他中文也乱码了,ok,一个个解决吧
1.tomcat本身输出的信息里中文乱码
要去tomcat里\conf\logging.properties文件把里面的编码encoding修改为GBK
1catalina.org.apache.juli.FileHandler.level = FINE
1catalina.org.apache.juli.FileHandler.directory = ${catalina.base}/logs
1catalina.org.apache.juli.FileHandler.prefix = catalina.
1catalina.org.apache.juli.FileHandler.encoding = GBK
2localhost.org.apache.juli.FileHandler.level = FINE
2localhost.org.apache.juli.FileHandler.directory = ${catalina.base}/logs
2localhost.org.apache.juli.FileHandler.prefix = localhost.
2localhost.org.apache.juli.FileHandler.encoding = GBK
3manager.org.apache.juli.FileHandler.level = FINE
3manager.org.apache.juli.FileHandler.directory = ${catalina.base}/logs
3manager.org.apache.juli.FileHandler.prefix = manager.
3manager.org.apache.juli.FileHandler.encoding = GBK
4host-manager.org.apache.juli.FileHandler.level = FINE
4host-manager.org.apache.juli.FileHandler.directory = ${catalina.base}/logs
4host-manager.org.apache.juli.FileHandler.prefix = host-manager.
4host-manager.org.apache.juli.FileHandler.encoding = GBK
java.util.logging.ConsoleHandler.level = FINE
java.util.logging.ConsoleHandler.formatter = java.util.logging.SimpleFormatter
java.util.logging.ConsoleHandler.encoding = GBK
2.log4j的中文乱码,启动的时候可能还会有平台输出的log4j信息,如果乱码可这样解决,将
log4j.properties文件里的控制台打印编码改为GBK即可
log4j.appender.Console.Encoding=GBK
3.最后的system.out.println里的中文乱码,老实说,这个搞了好久,但是解决了之后发现很简单
就是在代码里面的打印之前加上一条代码
System.setOut(new PrintStream(System.out, true, "GBK"));
没错,你没看错,就这么简单,具体原理我也说不清楚,大概就是jvm输出流的时候必须是GBK编码,因为windows控制台的编码就是GBK(不建议修改windows系统里面的编码),所以在代码里面sout时需要配置告诉一下我要的输出流编码是GBK,如图所示,个人理解如有错误的话欢迎评论告知
总结
如果用着没问题的时候,tomcat什么都不用动,如果是需要用到osssdk时,就要在tomcat里面的jvm配置一下encoding为utf8,任何时候控制台打印最好用log4j,不要用system.out
好了,就这样吧