IBM®
跳转到主要内容
    中国 [选择]    使用条款
 
 
Select a scope:Search for:    
    首页    产品    服务与解决方案     支持与下载    个性化服务    
跳转到主要内容

developerWorks 中国  >  Java technology | Web development  >

利用标记库国际化JSP(1)

developerWorks
文档选项

未显示需要 JavaScript 的文档选项


级别: 初级

翟斌(David Zhai) (zhaibin@yahoo.com),

2002 年 5 月 16 日

本文对JSP国际化的简要介绍,着重探讨了使用标记库对JSP进行国际化的过程,并通过详细的示例演示了如何使用jakarta的i18n标记库。

综述

当我们在用JSP设计面对不同国家的站点时,特别是那些在界面之间没有特别大差别的商业站点,我们可以利用JSP的一些机制来支持国际化。

通常有三种方式可以实现国际化

  • 为每个国家编写一套JSP代码, 可以通过嵌入BEAN和标记处理器的方式重用一些逻辑代码。
  • 维护统一的JSP代码,直接利用JAVA的资源捆绑机制实现国际化。
  • 维护统一的JSP代码,利用通用的或自定义标记库实现国际化。

我们重点讨论第三种方法,因为它有很好的灵活性,可维护性和可扩展性。

其实标记库也是利用JAVA的资源捆绑机制, 只是把国际化常用的方法封装的更容易使用,而且更符合JSP的编程思想, 把表述层和逻辑层分开。通用的标记库比较著名的有JAKARTA的I18N标记库。本文包括以下内容:

  • JSP国际化的简介
  • 如何配置i18n标记库
  • 详细介绍i18n标记库的各种标记和使用方法
  • 一个简单的例子




回页首


JSP国际化的简介

JSP的国际化的基础是JAVA的国际化,都是利用资源捆绑机制把资源与代码分离,通过读取相应的locale信息,自动的匹配相应的资源,并在此基础上实现文本,时间,日期,货币,数字等格式的国际化。关于JAVA国际化的基本概念和方法见 The Java TMTutorial Internationalization

但同一般的JAVA程序的国际化的过程和具体方法还是有很多区别。主要在与locale信息的来源: JSP的locale信息在大部分情况下来自与浏览器,而一般的JAVA程序的locale大都来自当前的JVM。

利用JSP的标记库机制实现国际化:通过使用通用或用户自定义的I18N标记库,可以有很好的灵活性,可维护性和可扩展性。但需要在服务器端配置标记库。





回页首


如何配置i18n标记库

首先需要一个支持JavaServer Pages Specification 1.1或更高版本的servlet容器,如Tomcat 4.03,然后按以下步骤配置你的网络服务器。

  • 拷贝标记库的描述文件到网络服务器的/WEB-INF子目录中
  • 拷贝标记库的JAR文件到网络服务器的/WEB-INF/lib子目录中
  • 在/WEB-INF/web.xml文件中加入<taglib>元素
<taglib>
  <taglib-uri>http://jakarta.apache.org/taglibs/i18n-1.0</taglib-uri>
  <taglib-location>/WEB-INF/i18n.tld</taglib-location>
</taglib>

为了在你的JSP中可以使用它,在每个页面的最顶端加入

<%@ taglib uri="http://jakarta.apache.org/taglibs/i18n-1.0" prefix="i18n" %>

其中"i18n"是该标记的前缀,您可以起其他你喜欢的名字。





回页首


i18n标记库的各种标记和使用方法

bundle

为该页的其他I18N标记建立ResourceBundle.如果没有给定locale信息,它会使用浏览器的设定。

注意:该标记必须写在该页任何HTML标记以前,以便根据所选择的locale信息设置Content Type。

<%@ taglib uri="http://jakarta.apache.org/taglibs/i18n-1.0" prefix="i18n" %>
<i18n:bundle baseName="i18n-test"
             id="bundle"/>
<HTML>
<HEAD>
......

表1:bundle的属性描述

属性名称描述
id 该ResourceBundle的标识变量, 通过它,其他标记和代码可以访问该ResourceBundle, 当一个页面需要多个ResourceBundle时,可以用它来区分.
baseNameResourceBundle 的基本名,可以连同locale信息定位所需的ResourceBundle.
changeResponseLocale指定是否改变响应的locale以匹配该标记所用的locale
scope指定该标记可被访问的范围. (application, session, request, page*)
locale用户可以指定首选的locale
localeAttribute不赞成使用
localeRef用户可以用属性名指定首选的locale,这个属性名必须在可被访问的范围内
debug调试开关

*page: 对象被绑定到javax.servlet.jsp.PageContent中,只在该页中可被访问

Request: 对象被绑定到javax.servlet.ServletRequest中,只要HttpRequest对象存在,就可以通过它访问。

Session: 对象被绑定到javax.servlet.jsp.PageContent中,并调用session的getArribute()方法来访问。

Application: 对象被绑定到javax.servlet.ServletContext中,是最持久的范围,所有客户都可以访问到。

Message

从默认或指定的ResourceBundle中读取文本并利用java.text.MessageFormat格式化显示文本

<i18n:message key="column1.header"/> 

表2:Message的属性描述

属性名称描述
id该Message的标识变量, 通过它,其他标记和代码可以访问该Message
key用它得到ResourceBundle中的显示文本
args利用数组参数通过java.text.MessageFormat格式化显示文本
bundle一个ResourceBundle的参考
bundleRef一个代表ResourceBundle的参考的属性名
debug调试开关

Locale





回页首


定义LOCALE 信息

JSP国际化和一般的JAVA应用程序国际化的最重要的区别在于Locale信息的源自浏览器, 具体的讲来自request对象.而jakarta的i18n标记库在缺省的情况下可以自动读取request对象中的Locale信息,从而简化了编程和维护的复杂度,当然用户也可以显式的定义Locale信息,解决特殊的显示问题。

表3:Locale的属性描述

属性名称描述
id该Locale的标识变量, 通过它,其他标记和代码可以访问该Locale
locale用户可以指定首选的locale
localeRef用户可以用属性名指定首选的locale,这个属性名必须在可被访问的范围内
language用户可以指定首选的语言
country用户可以指定首选的国家

一个简单的例子:

i18n-test.jsp

<%@ taglib uri="http://jakarta.apache.org/
taglibs/i18n-1.0" prefix="i18n" %>
<i18n:bundle baseName="i18n-test"
             id="bundle"/>
<%
java.util.TreeSet set = new java.util.TreeSet();
for ( java.util.Enumeration enum = bundle.getKeys(); 
enum.hasMoreElements(); )
  {
  set.add(enum.nextElement());
  }
%>
<HTML>
<HEAD>
  <TITLE>Examples of I18N Custom Tag Library 
  Tag Usage</TITLE>
</HEAD>
<BODY>
This page displays all key/value pairs in the bundle.
locale = <b><%= pageContext.getResponse().
getLocale() %></b><br>
charset = <b><%= pageContext.getResponse().
getCharacterEncoding() %></b><br>
<H2>WebApp translations</H2>
<TABLE>
<%
int index = 0;
for ( java.util.Iterator iter = set.iterator(); iter.hasNext(); )
  {
  String akey = (String)iter.next();
  if ( index++ % 2 == 0 )
    {
    %>
    <TR BGCOLOR="#e0e0e0">
    <%
    }
  else
    {
    %>
    <TR>
    <%
    }
    %>
  <TD><%= akey %></TD><TD><
  i18n:message key="<%= akey %>" /><TD>
  </TR>
  <%
  }
%>
</TABLE>
</BODY>
</HTML>
 

i18n-test.properties

test1 = Hello world
test2 = Now you can let jsp i18n using i18n taglib!

i18n-test_zh_CN.properties

test1 = 你好世界
test2 = 现在你可以用i18n标记库国际化JSP了。

注意要把资源文件拷贝到/WEB-INF/classes子目录下





回页首


标记库和源代码下载

taglibs.zip




回页首


下节介绍

利用I18N 标记库, 除了可以方便的对文字国际化外,还可以对各种格式进行国际化,如时间,日期,货币,数字等. 我们下次再讨论。



关于作者

翟斌(David Zhai)毕业与北京航空航天大学自动控制专业,学士学位。毕业后一直从事软件开发工作,对网络安全,国际化/本地化有一定的研究。现任职于北京一家开发软件国际化工具的专业公司,从事软件国际化工具的研发。联系方式: zhaibin@yahoo.com




对本文的评价

太差! (1)
需提高 (2)
一般;尚可 (3)
好文章 (4)
真棒!(5)

建议?




回页首


IBM 公司保留在 developerWorks 网站上发表的内容的著作权。未经IBM公司或原始作者的书面明确许可,请勿转载。如果您希望转载,请通过 提交转载请求表单 联系我们的编辑团队。
    关于 IBM 隐私条约 联系 IBM 使用条款