{{{
#!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",""); 
%>
<%
locale = new Locale("en",""); 
%>
}}}
== 結果 ==
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
}}}