Struts1.x系列教程(3):属性(资源)文件乱码问题的解决之道 - 编程入门网
Struts1.x系列教程(3):属性(资源)文件乱码问题的解决之道时间:2011-01-10 BlogJava 银河使者一、使用native2ascii命令使资源文件支持中文 从上篇文章中的ErrorDescription.properties文件中可以看到所有的错误提示信息都是英文的。在客户端显示这些英文信息没有任何问题。但如果将这些英文错误提示信息改成相应的中错误提示信息又会如何呢? 在修改之前,先让我们选中ErrorDescription.properties文件,单击右键,在右键菜单中选择【Properties】菜单项,打开属性设置对话框,在右侧所列的项目中选择【Resource】。看一下右下角的“Text file encoding”的编码格式,如果编码格式不是UTF-8或GBK(也包括GB2312、GB18030),请将编码格式修改为UTF-8或GBK,否则无法使用MyEclipse的属性编辑器输入中文。在设置完属性文件的编码格式后,将ErrorDescription.properties文件的内容按着该文件的英文版所示修改成中文提示信息。 中文版的ErrorDescription.properties error.user.blank=用户名不能为空. error.password.blank=密码不能为空. error.password1.confirmation=密码不匹配. error.email.blank=Email不能为空 error.email.invalid=不是一个正确的email地址 重新启动Tomcat后,在IE中输入如下的URL: http://localhost:8080/samples/simpleValidation.jsp 当出现信息输入界面后,点击“提交”按钮,将会显示如图1的效果。 图1 也许很多读者会感到奇怪。我们已经将属性文件的编码格式修改为UTF-8或GBK了,而且所输入的中文在MyEclipse中也能正常显示,并且页面中的设置的编码格式也和属性文件中的编码格式一致,那么为什么会输出乱码呢? 产生这个问题的原因要从Java对各种类型的文件的处理方式上说起。Java在处理*.java文件时,无论*.java文件的编码格式是UTF-8还是GBK。在使用javac.exe编译时,都会将其转换成UCS-2编码格式。因此,*.java文件就不会出现乱码。而Java在处理属性文件时,只能处理ISO 8859-1(也称为latin-1或“西欧语言”)或UCS-2(\uxxxx格式)编码格式。因此,如果在属性文件中含有其他编码格式的字符,如GBK,Java仍然会按着ISO 8859-1编码格式来解释这些字符(如果遇到以"u开头的字符,就会按着UCS-2编码格式处理),所以就会出现图1所示的显示效果。 Struts1.x系列教程(3):属性(资源)文件乱码问题的解决之道(2)时间:2011-01-10 BlogJava 银河使者解决这个问题的方法也很简单,在JDK中提供了一个native2ascii.exe命令(在<JDK安装目录>"bin目录中),这个命令用来将属性文件中的非ISO 8859-1格式的字符转换成\uxxxx格式的UCS-2编码格式。如按GBK编码的“用户”就会被转换成UCS-2编码格式的“\u7528\u6237”。 我们可以使用如下的命令转换ErrorDescription.properties文件的编码格式: <JDK安装目录>\bin\native2ascii ErrorDescription.properties ErrorDescription.properties 使用上面的命令将覆盖旧的ErrorDescription.properties文件,如果读者想保留旧的属性文件,可以将native2ascii.exe的第二个命令行参数换成其他的文件名,如下面命令所示: <JDK安装目录>\bin\native2ascii ErrorDescription.properties newDescription.properties 下面的内容显示了ErrorDescription.properties文件被转换了编码格式后的内容: 被转换了编码格式后的ErrorDescription.properties
|
凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢! |