java log 乱码_Java日志文件乱码

前言

计算机中储存的信息都是用二进制数表示的;而我们在屏幕上看到的英文、汉字等字符是二进制数转换之后的结果。通俗的说,按照何种规则将字符存储在计算机中,如'a'用什么表示,称为"编码";反之,将存储在计算机中的二进制数解析显示出来,称为"解码",如同密码学中的加密和解密。在解码过程中,如果使用了错误的解码规则,则导致'a'解析成'b'或者乱码。

出现乱码问题,一般是由于编码字符集与解码字符集不一致导致。

问题

新应用发布到新的服务器中,出现日志文件中文乱码的问题。见下图中的nickName:

9ebd039121d2

日志中文乱码

过程

查看文件的解码字符集。将日志download到自己电脑上使用notepad或者其他文本编辑器查看文件编码,发现文件的编码格式为utf-8,即解码字符集为utf-8。

2.查看文件的编码字符集。 通过下面的Java代码获取java虚拟机使用的字符集

String charsetName = Charset.defaultCharset().name();

发现Java虚拟机使用的字符集为US-ASCII。非utf-8。编码字符集与解码字符集不一致导致。

解决方法

在Java应用程序启动时添加启动参数-Dfile.encoding=utf-8即可,如是tomcat,在tomcat的配置文件tomcat.conf中的变量JAVA_OPTS添加-Dfile.encoding=utf-8即可。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值