Tomcat启动控制台乱码解决方案

前言

        事情的起因是这样的,当时我用了阿里云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

好了,就这样吧

  • 3
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值