有这样的一个需求,将数据库里的数据导出到execl表格中,我使用了jxl来编写,导出的execl文件存放在该项目的根目录/resources文件夹下,文件命名中有中文.
本地测试的时候,环境是linux操作系统,tomcat7.0服务器,且tomcat的配置为默认配置
执行程序返回一个下载该execl表格的url
http://localhost:8080/xxx-server/resources/data/xxxx记录表.xls
磁盘存储的文件
本地测试显示全部OK.
放到远程服务器上,环境与本地的一致.
但是生成的文件名称为乱码,但文件未损坏,且返回的url地址完全正确,没有出现乱码现象
这是在远程服务器上生成的文件
第一,确保tomcat的编码是utf-8,修改catlina.sh文件,在文件的开头添加
JAVA_OPTS="-Dfile.encoding=UTF-8 -Dsun.jnu.encoding=UTF-8"
第二,服务器的系统编码也是utf-8
# 查看系统默认编码(如果是zh_CN.utf8,则不用修改)
locale
# 使用管理员权限进行以下操作
localedef -c -f UTF-8 -i zh_CN zh_CN.utf8
export LC_ALL=zh_CN.utf8
就可以解决中文乱码问题了.