Linux中java log输出中文乱码 中文变“?”

原文地址:http://blog.csdn.net/clementad/article/details/51644416


比如这样一段代码:

[java]  view plain  copy
 
  1. logger.debug("中文乱码?Chinese");  
输出结果是这样的:

2016-06-12 10:24:46,130:DEBUG main (CleanupTaskTest.Java:27) - ?????Chinese


运行locale命令看一下结果:

[plain]  view plain  copy
 
  1. [root@localhost logs]# locale  
  2. LANG=  
  3. LC_CTYPE="POSIX"  
  4. LC_NUMERIC="POSIX"  
  5. LC_TIME="POSIX"  
  6. LC_COLLATE="POSIX"  
  7. LC_MONETARY="POSIX"  
  8. LC_MESSAGES="POSIX"  
  9. LC_PAPER="POSIX"  
  10. LC_NAME="POSIX"  
  11. LC_ADDRESS="POSIX"  
  12. LC_TELEPHONE="POSIX"  
  13. LC_MEASUREMENT="POSIX"  
  14. LC_IDENTIFICATION="POSIX"  
  15. LC_ALL=  

几个主要变量的意思:

1. LC_COLLATE:定义该环境的排序和比较规则
2. LC_CTYPE:用于字符分类和字符串处理,控制所有字符的处理方式,包括字符编码,字符是单字节还是多字节,如何打印等。是最重要的一个环境变量。
3. LC_MONETARY:货币格式
4. LC_NUMERIC:非货币的数字显示格式
5. LC_TIME:时间和日期格式
6. LC_MESSAGES:提示信息的语言。另外还有一个LANGUAGE参数,它与LC_MESSAGES相似,但如果该参数一旦设置,则LC_MESSAGES参数就会失效。LANGUAGE参数可同时设置多种语言信息,如
LANGUANE=”zh_CN.GB18030:zh_CN.GB2312:zh_CN”。
7. LANG:LC_*的默认值,是最低级别的设置,如果LC_*没有设置,则使用该值。类似于 LC_ALL。
8. LC_ALL:它是一个宏,如果该值设置了,则该值会覆盖所有LC_*的设置值。注意,LANG的值不受该宏影响。


解决方法:

把LC_CTYPE修改为“zh_CN.UTF-8”:

cd ~
vi .bashrc

添加:

export LANG='POSIX'
export LC_CTYPE='zh_CN.UTF-8'

生效:source .bashrc


这里我补充一下我的linux服务器 版本是 Centos 7

Linux中java log输出中文乱码 中文变“?”_第1张图片


.bashrc 这个文件是在 “根目录/~ " 下的

 修改完成后一定要 source .bashrc  一下不然只有重启服务器才会生效


这里还有二种办法:

1、系统必须安装中文语言包才行
# yum -y groupinstall chinese-support

2、仅仅有语言包还不行,我们得设置相应的字符集

  
## 或者,编辑 /etc/profile配置文件,添加如下一行 
export LANG="zh_CN.UTF-8"
# 重新载入 
# . /etc/profile 

  如图:

Linux中java log输出中文乱码 中文变“?”_第2张图片



你可能感兴趣的:(linux)