{{{ #!html
JSP 支援多國語系
Tomcat + JSP + i18n + taglib + utf-8 轉碼法
}}} [[PageOutline]] = update = * 2011/09/15 補充 utf 8 轉碼法 = 環境 = * sun java jdk 6 * tomcat 6 * 參數說明 || $_tomcat_ || 代表你放tomcat的路徑。如 /opt/tomcat/ || || $_project_ || 代表你的project 名稱。如:i18n || || $_workspace_ || 代表你Eclipse該專案所放置的路徑。如:/home/myname/workspace/ || * '''以下提供兩種實做的方法,第一種是直接放到 tomcat 下的目錄下;第二種方法用Eclipse 輔助編輯與即時編譯 ,可擇一實做''' = 說明 = 開發jps上的i18n,基本上要準備的有 (Tomcat + JSP + i18n + taglib) 並且將內容分成三大部份,1. i18n函式庫設定 2. 多國語系參數properties檔 3. JSP 程式碼 == 1. i18n函式庫設定 == 首先要把 i18n 的taglibs-i18n.jar 包找到,放到我們要引用的tomcat 專案目錄中,用 taglibs-i18n.tld 描述這個jar ,而web.xml 則要告訴tomcat 要用到的 taglibs-i18n.tld 與 http://jakarta.apache.org/taglibs/i18n-1.0 建立連結。 如此,則i18n與taglib 的環境則準備好了 === web.xml === || Tomcat || $_tomcat_/webapps/$_project_/WEB-INF/web.xml || || Eclipse || $_workspace_/$_project_/WebContent/WEB-INF/web.xml || {{{ #!xml i18n index.html index.htm index.jsp http://jakarta.apache.org/taglibs/i18n-1.0 /WEB-INF/taglibs-i18n.tld }}} === taglibs-i18n.tld === || Tomcat || $_tomcat_/webapps/$_project_/WEB-INF/taglibs-i18n.tld || || Eclipse || $_workspace_/$_project_/WebContent/WEB-INF/taglibs-i18n.tld || [http://trac.nchc.org.tw/cloud/raw-attachment/wiki/waue/2010/0805/taglibs-i18n.tld (可下載附件)] === taglibs-i18n.jar === || Tomcat || $_tomcat_/webapps/$_project_/WEB-INF/lib/taglibs-i18n.jar || || Eclipse || $_workspace_/$_project_/WebContent/WEB-INF/lib/taglibs-i18n.jar || [http://trac.nchc.org.tw/cloud/raw-attachment/wiki/waue/2010/0805/taglibs-i18n.jar (可下載附件)] == 2. 多國語系參數properties檔 == 多國語系目前較好的用法是,我們設計一個 jps 檔,當他out.print 的時候是用參數的方法印出,而參數的語系則交由使用者或程式來決定 因此,同一個參數 test1 ,我們需要 i18n_en.properties 來定義英文版本;i18n_zh_TW.properties 來定義中文版本;...依此類推 這個範例中,為了專案程式碼目錄的整潔度而言,將properties 檔放到 org/mytest/ 下,若看官想放其他目錄,需注意與jsp檔 程式碼的搭配。 === i18n_en.properties === || Tomcat || $_tomcat_/webapps/$_project_/WEB-INF/classes/org/mytest/i18n_en.properties || || Eclipse || $_workspace_/$_project_/src/org/mytest/i18n_en.properties || {{{ #!text test1 = Hello world test2 = Now you can let jsp i18n using i18n taglib! }}} === i18n_zh_TW.properties === || Tomcat || $_tomcat_/webapps/$_project_/WEB-INF/classes/org/mytest/i18n_zh_TW.properties || || Eclipse || $_workspace_/$_project_/src/org/mytest/i18n_zh_TW.properties || {{{ #!text test1 = 你好!世界 test2 = 你現在已經能讓你的JSP使用I18N的taglib跟世界接軌囉! }}} == 3. JSP 程式碼 == === index.jsp === || Tomcat || $_tomcat_/webapps/$_project_/index.jsp || || Eclipse || $_workspace_/$_project_/WebContent/index.jsp || {{{ #!java <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8" import="java.io.*,java.text.*,java.util.*,javax.servlet.jsp.*" %> <%@ taglib uri="http://jakarta.apache.org/taglibs/i18n-1.0" prefix="i18n" %> <%@ taglib prefix="fmt" uri="http://java.sun.com/jsp/jstl/fmt" %> <%@ taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %> Examples of I18N Custom Tag Library Tag Usage This page displays all key/value pairs in the bundle. locale = <%= pageContext.getResponse().getLocale() %>
charset = <%= pageContext.getResponse().getCharacterEncoding() %>

WebApp translations

<% Locale locale = new Locale("zh",""); %>
1
2
<% locale = new Locale("en",""); %>
1
2
}}} == 結果 == http://localhost:8080/$_project_/index.jsp {{{ #!html Examples of I18N Custom Tag Library Tag Usage This page displays all key/value pairs in the bundle. locale = zh_TW
charset = UTF-8

WebApp translations

1 你好!世界
2 你現在已經能讓你的JSP使用I18N的taglib跟世界接軌囉!
}}} = utf-8 轉碼工具 = == 網頁工具 == * 網頁轉碼工具 [http://www.tool.la/UTF-8/] 文字資訊轉檔 == java 工具 == * java 的自帶工具 此方法為整份文件轉檔的好招 先建立中文properties 檔(取名為 lang_zh_TW.properties.temp) === 中->碼 === 中文 => utf8碼 (歡 -> \u5c1a) {{{ /usr/lib/jvm/java-6-sun/bin/native2ascii lang_zh_TW.properties.temp lang_zh_TW.properties }}} 則 lang_zh_TW.properties 完成 === 碼->中 === 之後若要修改,可用還原指令: utf8碼 => 中文 (\u5c1a -> 歡) {{{ /usr/lib/jvm/java-6-sun/bin/native2ascii -reverse lang_zh_TW.properties lang_zh_TW.properties.temp }}}