问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

I18N-国际化消息和日志

发布网友 发布时间:2023-05-02 04:43

我来回答

1个回答

热心网友 时间:2023-10-14 23:43


摘要:     对于许多软件开发者来说 一提到国际化(亦称为 i n)支持就会感到害怕 要使编写的代码能够面向外国使用者 确实需要费一翻思量 因为在现有软件的代码中添加国际化支持可不是一件轻而易举的事 对于许多软件开发者来说 一提到国际化(亦称为 i n)支持就会感到害怕 要使编写的代码能够面向外国使用者 确实需要费一翻思量 因为在现有软件的代码中添加国际化支持可不是一件轻而易举的事 如果您感觉到软件需要支持不同语言和语言环境 哪怕这种可能性很小 从一开始就做国际化项目的准备 比起项目开始后再试图添加国际化支持也要明智得多     有人问 国际化 是什么意思? 国际化远不止于将用户界面消息翻译成不同的语言 它还涉及到处理不同的字符编码 日期/时间/货币的显示形式 以及跨多区域时存在的一些其他差异 介绍 i nlog    本文的目的并不在于讨论那些关于国际化的琐碎的方面 而是通过研究一个称为 I N Messages and Logging (简称 i nlog) 的开源项目 来介绍引入国际化功能时需要执行的一些必要的任务i nlog 允许您在 Java 应用程序内集成国际化的消息 这是通过向以下内容提供 API 来完成的 +标注 Java 类以识别国际化消息 +从所有支持的语言环境资源包中获取国际化消息 +创建特定于语言环境的异常 并在其中使用国际化的消息 +使用任何日志框架创建国际化消息日志 +自动生成特定于语言环境的资源包 +自动生成帮助及参考文档   定义国际化消息    国际化软件时一项最为乏味的工作莫过于维护资源绑定包了 资源绑定包是包含 name=value 这种信息对的属性文件 ( properties) 其中 name 是资源绑定包的关键字字符串 (key string) 而 value 是翻译过的消息字符串本身 习惯上为每种语言创建一个资源绑定包 在每个绑定包中关键字的设置是唯一的 而各个关键字相关的值就要翻译成各种语言了 资源绑定文件的名称应该指明它是为哪种语言创建的 例如 mybundle_en properties 文件中的消息是用英语写的 而 mybundle_de properties 包含德语消息     i nlog 提供了一些用于定义资源绑定消息及其关键字字符串的标注 用于将资源注入到 i nlog 的自定义 Ant 任务中 您可以自动生成资源绑定包 而不必为确保属性文件与访问属性文件的 Java 代码之间的一致性作过多的工作     @I NMessage 标注被放在常量上 这些常量就是资源绑定包的关键字字符串使用的常量 使用这些常量可以迫使执行编译时检查 例如代码中引入的拼写错误(如常量名称的拼写错误)和使用过时消息或已删除消息 这些错误在编译时就可以被探测到 以下是使用此标注的示例 java 代码

           @I NMessage( Hello { } You last visited on { date} )           public static final String MSG_WELE = example wele msg ;  

    上面的示例定义了一条国际化消息 常量的值定义了资源绑定包的关键字字符串(key string) 标注的值是一条实际翻译好的消息 您可以将这些标注过的常量放到应用程序的任何类或接口中 可以将它们放在单独的类或接口中(将所有消息定义集中到一个地点) 也可以放在使用到它们的类中     @I NResourceBundle 标注用于定义存放消息的资源绑定包文件( properties 文件) 它可以标注整个类或接口 也可以标注特定的部分 如果您标注了一个类或接口 则该类或接口中的所有 @I NMessage 标注都将被存储在该标注定义的资源绑定包中(默认情况下) 如果只将标注放在特定的常量上 那么它就只是那个常量的绑定包 以下是使用此标注的示例 java 代码

           @I NResourceBundle( baseName = messages                                 defaultLocale = en )  

    以上代码的意思是 所有被 @I NMessage 标注的相关消息都将放置在名为 messages_en properties 绑定包文件中 下面是一个更复杂的示例(包含一系列国际化消息的接口) java 代码

           @I NResourceBundle( baseName = messages                                   defaultLocale = en )             public interface Messages {                @I NMessage( Hello { } You last visited on { date} )                String MSG_WELE = wele msg ;                           @I NMessage( An error occurred please try again )                String MSG_ERR = error occurred ;                           @I NMessage( The value is { } )                String MSG_VALUE = value ;             }  

检索国际化消息    定义了国际化常量后 就可以使用 i nlog 的核心类提供的 API mazz i n Msg 该 API 用于装载存放于资源绑定属性文件中的消息 它还用于将值作为变量参数进行传递 从而替换消息中的占位符(例如 { } { date}) 另外 此 API 将您从直接使用 JDK 类进行编码的工作中解放出来 也许您需要阅读一下 Javadoc 的 java text MessageFormat 部分 以获得对 i nlog 工作原理的初步认识 尤其是它如何使用本地化的数据替换占位符 下面是 Msg 类的使用实例 java 代码

           // 使用静态工厂方法创建一个 Msg 对象           // 假设默认绑定包的名字是 messages            System out println( Msg createMsg( Messages MSG_WELE                                               name                                               date ) );  

和java 代码

           // 使用构造函数创建一个 Msg 对象           Msg msg = new Msg( new Msg BundleBaseName( messages ) );           try {              String hello = msg getMsg(Messages MSG_WELE name date );              do something            }           catch (Exception e) {              throw new RuntimeException( msg getMsg( Messages MSG_ERR ) );           }  

  name 和 date 参数是传递一个任意参数列表的示例 每个对象代表各个位置上要被替换掉的占位符({ } 和 { date} 分别基于前面给出的 Messages MSG_WELE 中的定义)     Msg 对象会根据 绑定包的名称 及其当前的语言环境设置获知使用哪种语言环境的资源绑定包 绑定包的名称 是绑定包文件的名称减去语言环境符号和扩展名(在上面的示例中 绑定包的名称是 messages) 您可以通过传递到 Msg 的构造函数或者特定的静态工厂方法的方式 来定义 Msg 对象使用的 绑定包的名称 如果不进行明确地指定 将使用默认的 messages 绑定包的名称 在 Msg 对象的生命周期内将一直存在 可以通过调用 Msg 对象的 setLocale() 来切换语言环境(默认语言环境是 JVM 使用的语言环境) 如果您使用了 Msg 对象并且要求根据(被分配了 Msg 对象的)使用者的需要来切换语言环境 这将是非常有用的

本地化的异常    i nlog 提供了两个基本的异常类(分别用于已查看和未查看的异常 LocalizedException 和 LocalizedRuntimeException) 可以这两个类创建自己的本地化异常子类 这些类都具有构造函数 其函数签名与 Msg 类非常相似 在使用构造函数时 通过调用资源绑定包的关键字和占位符的变量参数列表的方法来指定异常消息 同时还可以选择绑定包的名称和语言环境 这样一来 异常消息就可以使用本地化的各种语言 其原理就是利用了 Msg 可以检索本地化的消息 创建国际化消息的日志    i nlog 提供了一种方法 可以通过该方法记录国际化的日志信息 日志系统的主类是 mazz i n Logger 它提供了 trace debug info warn error 和 fatal 方法等一些典型的设置 需要指出的是 与传递一个消息本身组成的字符串不同 您为占位符传递的是资源绑定包的关键字字符串和参数列表 它使用具有保护作用的 mazz i n Msg 类来获取实际的本地化消息     通过使用工厂类 mazz i n LoggerFactory 来获得 Logger 对象 与 log j 等获得对象的方式基本相同 而不同的是记录日志消息的方法 该方法与通过 mazz i n Msg 对象获取消息非常类似 java 代码

           public static final mazz i n Logger LOG =                          mazz i n LoggerFactory getLogger(MyClass class);                       LOG debug(Messages MSG_VALUE value);                       try {                         }           catch (Exception e) {              LOG warn(e Messages MSG_ERR);           }  

    如果没有启用日志级别 则不会查找绑定包 也不会执行任何字符串连接 这一条件有效地加快了日志调用的速度 如果日志消息与特定的表达式相关联 则需要将表达式的第一个参数传递给日志方法 如果启用了栈倾卸设置 这将允许栈跟踪倾卸消息(请往下看)     i nlog 的日志框架中还添加了许多其他的功能 这些功能并非潜在的 第三方的日志框架所能媲美 首先要介绍的功能就是 可以告诉 Logger 是否倾卸异常的栈跟踪 您可能需要查看一个特定运行任务的所有异常的栈跟踪 也可能不想看 请注意 对于在 FATAL 日志级别上的异常 不能禁用此功能 使用该方法记录的致命异常必需允许倾卸栈跟踪 对于其他的日志级别 日志程序只有在系统属性 i nlog mp stack traces 设置为 true (或者在代码中调用 Logger setDumpStackTraces(true))的时候才会倾泄栈跟踪     i nlog 日志框架附加的第二项功能是 在记录与一个消息关联的资源绑定包关键字的同时 记录消息本身 资源绑定包关键字对于所有语言环境都是相同的 也就是说 无论消息是用何种语言写成的 关键字是不变的 可以把这些关键字想象成 消息的 ID 或 错误的代码 这在生成涉及到这些代码的帮助文档时非常有用 用户将可以参考文档中的额外帮助文本 以得知到底要传递什么消息(关于如何生成这种文档 请查看下文) 在默认情况下 此功能处于启用状态 要禁用此功能 只需将系统属性 i nlog mp keys 设置为 false 或者在代码中调用 Logger setDumpLogKeys(false)     提供消息 ID 避免在已禁用日志级别上拼接字符串 这些 i nlog 提供的日志机制也许已经足够了 也许有人会争论说 将(除用户界面消息以外的)日志消息国际化是一种负担而且也没有必要 我有时也感到很难说服这种观点 如果项目没有这种需求 您当然不必使用国际化日志 即使不使用 i nlog 提供的日志功能 还可以使用它提供的其他功能嘛     但是 我还是可以举出一些具体的例子来证明使用国际化消息的好处 请注意 i nlog 允许定义一个不同的语言环境供日志程序使用(日志语言环境) 该语言环境区别于 Msg 实例使用的语言环境 这就可以帮助使用我的开发团队的语言来记录日志消息 而我的用户界面使用用户可以阅读的语言(可能与开发团队使用的语言不同) 例如 我的用户说德语 而软件是由说法语的法国团队开发的 在这种情况下 德国用户碰到一个问题时 就可以正常地给法国开发团队发送日志 软件可以默认地将语言环境设置为 Locale FRENCH 另一方面 如果德国用户希望自行调试问题 法语的日志消息根本不会有任何帮助 在这种情况下 德国用户简单地通过设置系统属性 将日志消息记录为德语 关于如何切换日志语言环境的信息 请参考 mazz i n LoggerLocale Javadoc 自动生成资源绑定包    i nlog 提供了一个 Ant 任务 用于自动生成资源绑定包属性文件 以避免开发者担负手动向属性文件中添加消息 清理过时消息的任务     该 Ant 任务将扫描类以查找 @I N 标注 并根据这些标注为您创建资源绑定包 这意味着 无论添加多少 @I NMessage 标注字段 它们都将被加入到资源绑定包中 如果您删除了一个国际化消息常量 则该消息也将从 Ant 任务生成的资源绑定包结果中删除 要运行该 Ant 任务 需要在 Ant 脚本中添加以下类似代码 xml 代码

           <taskdef name= i n                     classpat                    classname= mazz i n ant I NAntTask />                      <i n outputdir= ${classes dir} verify= true verbose= true >           <classpath refid= my classpath />              <classfileset dir= ${classes dir} />           i n>  

    必需让 Ant 任务知道含有国际化标注类及其依赖关系的类的类路径 还必须给出类文件集 其中包含文件集的文件列表供扫描国际化标注之用 建议您在第一次运行 Ant 任务的时候采用 冗长 模式 以便知道 Ant 任务的执行内容 一旦得到了想要的效果 再将 冗长 模式关闭 执行此任务之后 资源绑定包属性文件将出现在指定的输出目录中 生成帮助文档    使用此 Ant 任务的另一个可选功能是生成帮助文档 该文档是由所有对资源绑定包关键字名称及其消息值的引用组成的 另外还包含了对这些消息的描述 这是一个可在 @I NMessage 标注中指定的可选属性 help 属性 属性值可以是深入描述消息的任何字符串 可以将文档想象成在特定情况下将传递的具体消息 自动生成的帮助文档可以提供消息关键字 消息本身以及消息描述之间的交叉引用 java 代码

           @I NMessage( value= The value is { }                          help= This will show you the value of your                              + current counter If this value is over                              + you should reset it )           String MSG_VALUE = value ;                      @I NMessage( value= Memory has { } free bytes left                          help= The VM is very low on memory Increase Xmx            String MSG_LOW_MEM = low memory ;  

    大多数情况下 您可以将其作为 消息的 ID 或者 错误的代码 列表使用 可以将其中的资源绑定包关键字当成一个 消息 ID 或者 错误的代码 要生成帮助文档 需要在 任务中使用 内部标记 xml 代码

           <i n outputdir= ${classes dir} >           <classpath refid= my classpath />              <classfileset dir= ${classes dir} />              <helpdoc outputdir= ${doc dir}/help />           i n>  

  对于每个生成的资源绑定包 都可以在 <helpdoc> 中指定的目录下找到一个相应的帮助文档 文档是根据用于描述文档样式的模板生成的 默认情况下 模板是一个简单的 HTML 页 使用 <table> 标记消息代码 而输出就是帮助文档 在 <helpdoc> 标记中还可以指定一些其他的属性来自定义一个模板 以满足自行定制帮助文档外观的需求 有关更多信息 请查阅 mazz i n ant Helpdoc 类的 Javadoc     在帮助文档的生成结束之后 您就可以得到一个(或一些)包含消息关键字代码 消息内容及任何 help 属性定义内容的文档了 本地化

  我们已经讨论了许多关于如何通过获取翻译的消息和本地化的消息国际化软件的内容 嵌入国际化功能之后 剩下的工作就是手动处理那些需要被本地化的资源绑定属性文件(由 <i n> Ant 任务生成或者自行手动编写)了 必须确保将所有资源绑定包的消息翻译成需要支持的语言 而且这些消息包含的数据也进行相应的本地化 通过定义占位符属性(例如 { date} 将使用目标语言环境的格式和语言输出日期字符串)可以完成许多本地化方面的工作 不言而喻的是 必须找一家优秀的翻译和本地化公司

  小结

lishixin/Article/program/Java/hx/201311/26737
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
...flash学得好、将来会有什么用、求哥哥、姐姐们、帮帮忙 我即将初中毕业,想要读技校,但又不知选那科好`哥哥姐姐们帮个忙吧! 成绩不好,高中毕业想学电脑,哪位哥哥姐姐知道帮忙推荐下学校_百度知 ... 大学计算机3级 怎样学习啊 难吗 哥哥姐姐 帮帮忙吧 ...就业怎样?我报了这个专业,请各位哥哥姐姐帮帮忙 请IT业工作的哥哥姐姐帮忙出出主意~~ ...师傅让他沿着水缸边行走练功。有谁知道这个电影叫什么? 小伙穿越拜"小龙女"为师,与小龙女合练武功是什么电影 ...电影开头是一个赤膊的男主角在练功,然后再和队友们去做任务,结果一... ...一秒竟然穿越了醒来第一句话就是疼死宝宝了是什么电视剧? 掷梭的国语词典掷梭的国语词典是什么 南柯梦的解释南柯梦的解释是什么 忘归是什么意思 海尔中央空调铜管哪个品牌好用 空调铜管哪个牌子好 怎样增长自己的见识 怎么用PS把RGB图片变为CMYK图片 12nbl2830yj是什么轴承 六年级写元旦的作文500字 六年级欢庆元旦作文500字【六篇】 我的世界网易手机版如何利用命令方块来回传送? 我的世界传送指令大全 磕大头为什么越住后磕越难 磕响头才能保佑要咋回复 蝴蝶夹子手工教程 座机怎么查最后一个来电号码 3匹空调适合多大面积3匹空调一小时多少度电 眼鼻嘴中文音译 VIVO手机如何删除teleyphone? 如何删除teleyphone 研究生报录比多少比较合适 电视剧《问君能有几多愁》的结局? 梧州地震危害大不大 刚才距离几十千米外的梧州地震了,我这里感受到了震感,天气预报说会有雷电,大风,会不会意味着还有地震 佛山市南海区丹灶镇洲北工业区2016年7月31日下午5点20分左右有微微的地震感,你们感觉到了吗? 广西历史上有无发生过特大地震?如果有…有多大,死了多少人,有多少损失? 梧州市蒙山县地震7月31日 平安银行白领贷晚上能提现吗 黑狮声卡是哪里代工的 黑狮声卡和雅马哈声卡哪个好 为什么黑狮声卡为什么这么贵 黑狮声卡更适合女生还是男生 黑狮声卡和m8声卡哪个好 全脂牛奶和高蛋白牛奶区别 6款高蛋白的纯牛奶精选 最贵的鞋,最漂亮的鞋,最好的鞋,最合适的鞋 关于保险工作计划 保险代理人网上展业时需要做什么规划吗? 保险公司工作计划优秀范文示例三篇 项目延期备忘录模板怎么写