Java的I/O出现中文乱码及默认编码问题

来源:互联网 发布:windows jdk版本升级 编辑:程序博客网 时间:2024/06/05 03:36

问题 

  项目中遇到再从aix系统移植到linux系统过程,项目导出报表文件出现乱码。启动脚本与原来一样,有下面的语句但并未生效

LANG=ZH_CNexport LANG

问题分析

  从项目代码分析,代码中没有显示就行编码设置,于是导出文件的编码应该是系统默认编码,对于Java来说就是下面代码的值

System.getProperty("file.encoding")
其中file.encoding在eclipse中是启动文件本身的编码,右键Java文件Properties->Resource中Text file encoding的编码,和引用其他类文件的编码无关。

如果通过命令行进行调用Windows一般默认是GBK,linux中看LANG环境变量的配置,可以通过echo $LANG来看当前环境的编码。前面提到我脚本中已经设置LANG=ZH_CN却没有生效出现了中文乱码。因为项目之前的AIX系统存在中文编码叫ZH_CN,移植到的liunx系统存在的中文编码叫zh_CN,大小写不一样,系统找不到编码没有设置成功。linux可以通过locale命令查看当前环境的各种编码,通过locale -a查看当前系统支持的所有编码及其名称。

当然,可以通过jvm启动参数-Dfile.encoding=gbk来指定编码,这里的编码是Java的编码如gbk,utf-8等,并不是系统中的编码名称,个人感觉这种方式比较好。

阅读全文
0 0
原创粉丝点击