gpt4 book ai didi

Java 属性文件本地化和字符编码问题

转载 作者:行者123 更新时间:2023-11-29 09:50:05 25 4
gpt4 key购买 nike

我正在开发一个 Java 网络应用程序,该应用程序现在处于开发的最后阶段,剩下要做的事情之一就是本地化。我们正在为每个受支持的语言环境使用属性文件。我发现的问题是某些 unicode 字符在网络浏览器中显示不正确。网页在字符集元标记中指定了 UTF-8 编码,并且浏览器已正确检测到它(在 Firefox View->Character Encoding 中似乎选择了正确的编码)。我认为问题出在以下事实:虽然应用程序将文本显示为 UTF-8,但属性文件以 ISO*xxxx 编码保存,这恰好是一些 eclipse 默认设置。

我在这里发现了一个类似的问题:Java properties UTF-8 encoding in Eclipse这建议我安装资源包插件。我安装并使用插件编辑了相应的属性,但仍然有问题。

是否有一个快速的解决方案(我的意思是不会对应用程序造成太多更改的解决方案,因为它已接近完成阶段)可以解决我遇到的问题。

也许我应该提到我正在使用 Firefox 7 在 Ubuntu Linux OS 下开发和观察这个问题。提前致谢。

编辑:我没有提到一件重要的事情。我的用户界面是用 GWT 编写的,属性由一个接口(interface)公开,该接口(interface)在 GWT 用于在内部创建该接口(interface)的实现并链接到相应属性的 getter 上有注释。所以我想我对实际读取属性的方式没有太多控制,或者至少我不知道如何在 GWT 中执行此操作。

最佳答案

Java properties files是 ISO 8859-1 (Latin 1) 编码的。其他字符必须使用转义的 Unicode 表示。

因此,您不应将 Latin 1 以外的 Unicode 字符直接输入到您的本地化文件中。此类字符应按 Unicode 转义输入。

如果您有一堆 UTF-8(或其他)编码的属性文件,您可以使用 native2ascii 将它们翻译成 Latin 1 转义的 unicode| JDK 中的工具。此外,Ant 有一个 native2ascii task .

其他发帖人指出了解决此问题的方法。但就个人而言,我更愿意坚持属性资源文件中的标准编码——这样它就可以处理所有内容。没有什么可以阻止您以 UTF-8 编码编写文件并将它们转换为 Latin 1 转义 unicode 作为构建的一部分(例如 Ant 任务)。

关于Java 属性文件本地化和字符编码问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8211331/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com