<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    海鷗航際

    JAVA站
    posts - 11, comments - 53, trackbacks - 1, articles - 102

    Struts 原理與實(shí)踐(5)

    Posted on 2005-03-23 17:57 海天一鷗 閱讀(377) 評(píng)論(0)  編輯  收藏 所屬分類: Struts專題
    一個(gè)支持i18n的應(yīng)用程序應(yīng)該有如下一些特征:
    1增加支持的語(yǔ)言時(shí)要求不更改程序代碼
    2字符元素、消息、和圖象保存在原代碼之外
    3依賴于不同文化的數(shù)據(jù)如:日期時(shí)間、小數(shù)、及現(xiàn)金符號(hào)等數(shù)據(jù)對(duì)用戶的語(yǔ)言和地理位置應(yīng)該有正確的格式
    4應(yīng)用程序能迅速地適應(yīng)新語(yǔ)言和/或新地區(qū)

    Struts主要采用兩個(gè)i18n組件來(lái)實(shí)現(xiàn)國(guó)際化編程:

    第一個(gè)組件是一個(gè)被應(yīng)用程序控制器管理的消息類,它引用包含地區(qū)相關(guān)信息串的資源包。第二個(gè)組件是一個(gè)JSP定制標(biāo)簽,,它用于在View層呈現(xiàn)被控制器管理的實(shí)際的字符串。在我們前面的登錄例子中這兩方面的內(nèi)容都出現(xiàn)過(guò)。

    用Struts實(shí)現(xiàn)國(guó)際化編程的標(biāo)準(zhǔn)做法是:生成一個(gè)java屬性文件集。每個(gè)文件包含您的應(yīng)用程序要顯示的所有消息的鍵/值對(duì)。

    這些文件的命名要遵守如下規(guī)則,代表英文消息的文件可作為缺省的文件,它的名稱是ApplicationResources.properties;其他語(yǔ)種的文件在文件名中都要帶上相應(yīng)的地區(qū)和語(yǔ)言編碼串,如代表中文的文件名應(yīng)為ApplicationResources_zh_CN.properties。并且其他語(yǔ)種的文件與ApplicationResources.properties文件要放在同一目錄中。

    ApplicationResources.properties文件的鍵/值都是英文的,而其他語(yǔ)種文件的鍵是英文的,值則是對(duì)應(yīng)的語(yǔ)言。如在我們前面的登錄例子中的鍵/值對(duì):logon.jsp.prompt.username=Username:在中文文件中就是:logon.jsp.prompt.username=用戶名:當(dāng)然,在實(shí)際應(yīng)用時(shí)要把中文轉(zhuǎn)換為AscII碼。

    有了上一篇文章和以上介紹的一些基礎(chǔ)知識(shí)后。我們就可以將我們的登錄程序進(jìn)行國(guó)際化編程了。

    首先,我們所有jsp頁(yè)面文件的字符集都設(shè)置為UTF-8。即在頁(yè)面文件的開始寫如下指令行:

    <%@ page contentType="text/html; charset=UTF-8" %>,在我們的登錄例子中已經(jīng)這樣做了,這里不需要再改動(dòng)。

    其次,將所有的request的字符集也設(shè)置為UTF-8。雖然,我們可以在每個(gè)文件中加入這樣的句子:request.setCharacterEncoding("UTF-8");來(lái)解決,但這樣顯得很麻煩。一種更簡(jiǎn)單的解決方法是使用filter。具體步驟如下:

    在mystruts\WEB-INF\classes目錄下再新建一個(gè)名為filters的目錄,新建一個(gè)名為:SetCharacterEncodingFilter的類,并保存在該目錄下。其實(shí),這個(gè)類并不要您親自來(lái)寫,可以借用tomcat中的例子。現(xiàn)將該例子的程序節(jié)選如下:

    package filters;
    import java.io.IOException;
    import javax.servlet.Filter;
    import javax.servlet.FilterChain;
    import javax.servlet.FilterConfig;
    import javax.servlet.ServletException;
    import javax.servlet.ServletRequest;
    import javax.servlet.ServletResponse;
    import javax.servlet.UnavailableException;
    
    /**
     * <p>Example filter that sets the character encoding to be used in parsing the
     * incoming request, either unconditionally or only if the client did not
     * specify a character encoding.  Configuration of this filter is based on
     * the following initialization parameters:</p>
     * <ul>
     * <li><strong>encoding</strong> - The character encoding to be configured
     *     for this request, either conditionally or unconditionally based on
     *     the <code>ignore</code> initialization parameter.  This parameter
     *     is required, so there is no default.</li>
     * <li><strong>ignore</strong> - If set to "true", any character encoding
     *     specified by the client is ignored, and the value returned by the
     *     <code>selectEncoding()</code> method is set.  If set to "false,
     *     <code>selectEncoding()</code> is called <strong>only</strong> if the
     *     client has not already specified an encoding.  By default, this
     *     parameter is set to "true".</li>
     * </ul>
     *
     * <p>Although this filter can be used unchanged, it is also easy to
     * subclass it and make the <code>selectEncoding()</code> method more
     * intelligent about what encoding to choose, based on characteristics of
     * the incoming request (such as the values of the <code>Accept-Language</code>
     * and <code>User-Agent</code> headers, or a value stashed in the current
     * user's session.</p>
     *
     * @author Craig McClanahan
     * @version $Revision: 1.2 $ $Date: 2001/10/17 22:53:19 $
     */
    
    public class SetCharacterEncodingFilter implements Filter {
    
    
        // ----------------------------------------------------- Instance Variables
    
    
        /**
         * The default character encoding to set for requests that pass through
         * this filter.
         */
        protected String encoding = null;
    
    
        /**
         * The filter configuration object we are associated with.  If this value
         * is null, this filter instance is not currently configured.
         */
        protected FilterConfig filterConfig = null;
    
    
        /**
         * Should a character encoding specified by the client be ignored?
         */
        protected boolean ignore = true;
    
    
        // --------------------------------------------------------- Public Methods
    
    
        /**
         * Take this filter out of service.
         */
        public void destroy() {
    
            this.encoding = null;
            this.filterConfig = null;
    
        }
    
    
        /**
         * Select and set (if specified) the character encoding to be used to
         * interpret request parameters for this request.
         *
         * @param request The servlet request we are processing
         * @param result The servlet response we are creating
         * @param chain The filter chain we are processing
         *
         * @exception IOException if an input/output error occurs
         * @exception ServletException if a servlet error occurs
         */
        public void doFilter(ServletRequest request, ServletResponse response,
                             FilterChain chain)
            throws IOException, ServletException {
    
            // Conditionally select and set the character encoding to be used
            if (ignore || (request.getCharacterEncoding() == null)) {
                String encoding = selectEncoding(request);
                if (encoding != null)
                    request.setCharacterEncoding(encoding);
            }
    
            // Pass control on to the next filter
            chain.doFilter(request, response);
    
        }
    
    
        /**
         * Place this filter into service.
         *
         * @param filterConfig The filter configuration object
         */
        public void init(FilterConfig filterConfig) throws ServletException {
    
            this.filterConfig = filterConfig;
            this.encoding = filterConfig.getInitParameter("encoding");
            String value = filterConfig.getInitParameter("ignore");
            if (value == null)
                this.ignore = true;
            else if (value.equalsIgnoreCase("true"))
                this.ignore = true;
            else if (value.equalsIgnoreCase("yes"))
                this.ignore = true;
            else
                this.ignore = false;
    
        }
    
    
        // ------------------------------------------------------ Protected Methods
    
    
        /**
         * Select an appropriate character encoding to be used, based on the
         * characteristics of the current request and/or filter initialization
         * parameters.  If no character encoding should be set, return
         * <code>null</code>.
         * <p>
         * The default implementation unconditionally returns the value configured
         * by the <strong>encoding</strong> initialization parameter for this
         * filter.
         *
         * @param request The servlet request we are processing
         */
        protected String selectEncoding(ServletRequest request) {
    
            return (this.encoding);
    
        }
    
    }


    其中,request.setCharacterEncoding(encoding);是一個(gè)關(guān)鍵句子。

    為了讓該類工作,我們還要在web.xml文件中對(duì)它進(jìn)行配置,配置代碼如下:

    <filter>
        <filter-name>Set Character Encoding</filter-name>
        <filter-class>filters.SetCharacterEncodingFilter</filter-class>
        <init-param>
          <param-name>encoding</param-name>
          <param-value>UTF-8</param-value>
        </init-param>
      </filter>
      <filter-mapping>
        <filter-name>Set Character Encoding</filter-name>
        <url-pattern>/*</url-pattern>
      </filter-mapping>


    最后,就是準(zhǔn)備資源包文件,我們以創(chuàng)建一個(gè)中文文件為例:

    將ApplicationResources.properties文件打開,另存為ApplicationResources_zh.properties,這只是一個(gè)過(guò)渡性質(zhì)的文件。將文件中鍵/值對(duì)的值都用中文表示。更改完后的代碼如下:

    #Application Resource for the logon.jsp
    logon.jsp.title=登錄頁(yè)
    logon.jsp.page.heading=歡迎 世界!
    logon.jsp.prompt.username=用戶名:
    logon.jsp.prompt.password=口令:
    logon.jsp.prompt.submit=提交
    logon.jsp.prompt.reset=復(fù)位
    
    #Application Resource for the main.jsp
    main.jsp.title=主頁(yè)
    main.jsp.welcome=歡迎:
    
    #Application Resource for the LogonAction.java
    error.missing.username=<li><font color="red">沒(méi)有輸入用戶名</font></li>
    error.missing.password=<li><font color="red">沒(méi)有輸入口令</font></li>
    
    #Application Resource for the UserInfoBo.java
    error.noMatch=<li><font color="red">沒(méi)有匹配的用戶</font></li>
    
    #Application Resource for the UserInfoBo.java
    error.logon.invalid=<li><font color="red">用戶名/口令是無(wú)效的</font></li>
    error.removed.user=<li><font color="red">找不到該用戶</font></li>
    error.unexpected=<li><font color="red">不可預(yù)期的錯(cuò)誤</font></li>


    使用native2ascii工具將上面文件中的中文字符轉(zhuǎn)換為ascii碼,并生成一個(gè)最終使用的資源文件ApplicationResources_zh_CN.properties。

    具體做法是打開一個(gè)dos窗口,到mystruts\WEB-INF\classes目錄下,運(yùn)行如下語(yǔ)句:

    native2ascii -encoding GBK ApplicationResources_zh.properties ApplicationResources_zh_CN.properties

    生成的文件ApplicationResources_zh_CN.properties的內(nèi)容如下:

    #Application Resource for the logon.jsp
    logon.jsp.title=\u767b\u5f55\u9875
    logon.jsp.page.heading=\u6b22\u8fce \u4e16\u754c!
    logon.jsp.prompt.username=\u7528\u6237\u540d:
    logon.jsp.prompt.password=\u53e3\u4ee4:
    logon.jsp.prompt.submit=\u63d0\u4ea4
    logon.jsp.prompt.reset=\u590d\u4f4d
    
    #Application Resource for the main.jsp
    main.jsp.title=\u4e3b\u9875
    main.jsp.welcome=\u6b22\u8fce:
    
    #Application Resource for the LogonAction.java
    error.missing.username=<li><font color="red">\u6ca1\u6709\u8f93\u5165\u7528\u6237\u540d</font></li>
    error.missing.password=<li><font color="red">\u6ca1\u6709\u8f93\u5165\u53e3\u4ee4</font></li>
    
    #Application Resource for the UserInfoBo.java
    error.noMatch=<li><font color="red">\u6ca1\u6709\u5339\u914d\u7684\u7528\u6237</font></li>
    
    #Application Resource for the UserInfoBo.java
    error.logon.invalid=<li><font color="red">\u7528\u6237\u540d/\u53e3\u4ee4\u662f\u65e0\u6548\u7684</font></li>
    error.removed.user=<li><font color="red">\u627e\u4e0d\u5230\u8be5\u7528\u6237</font></li>
    error.unexpected=<li><font color="red">\u4e0d\u53ef\u9884\u671f\u7684\u9519\u8bef</font></li>


    從這里可以看出,所有的中文字都轉(zhuǎn)換成了對(duì)應(yīng)的Unicode碼。

    現(xiàn)在,再運(yùn)行登錄例子程序,您會(huì)發(fā)現(xiàn)它已經(jīng)是顯示的中文了。在瀏覽器的"工具"--"Internet選項(xiàng)"的"語(yǔ)言首選項(xiàng)"對(duì)話框中,去掉"中文(中國(guó))"加上英文,再試登錄程序,此時(shí),又會(huì)顯示英文。這就是說(shuō)不同國(guó)家(地區(qū))的客戶都可以看到自己語(yǔ)言的內(nèi)容,這就實(shí)現(xiàn)了國(guó)際化編程的基本要求。如果還要顯示其他語(yǔ)言,可采用類似處理中文的方法進(jìn)行,這里就不細(xì)講了。

    本文中的例子程序所采用的數(shù)據(jù)庫(kù)仍然是MS SQLServer2000,數(shù)據(jù)庫(kù)字符集為gbk。實(shí)驗(yàn)表明,對(duì)簡(jiǎn)、繁體中文,英文及日文字符都能支持。

    參考文獻(xiàn):
    《Programming Jakarta Struts》Chuck Cavaness著
    《Mastering Jakarta Struts》James Goodwill著
    主站蜘蛛池模板: 拍拍拍无挡免费视频网站| 最近中文字幕2019高清免费| 亚洲成a人片在线观看无码| 18未年禁止免费观看| 亚洲妇女无套内射精| 亚洲欧洲国产精品香蕉网| 成人免费毛片内射美女-百度| 久久精品国产亚洲AV天海翼| 亚洲日本一区二区| 日韩免费a级在线观看| 免费福利在线视频| 亚洲中文字幕无码中文| 亚洲AV人无码激艳猛片| 午夜无遮挡羞羞漫画免费| 久久国产精品成人免费| 亚洲日韩av无码中文| 亚洲卡一卡2卡三卡4卡无卡三| 国产成人无码区免费A∨视频网站| a级毛片100部免费观看| 亚洲成a人无码亚洲成av无码| 亚洲第一精品在线视频| 免费在线视频一区| 国产成人免费网站| 黄色网站软件app在线观看免费| 亚洲欧美成人一区二区三区| 亚洲情a成黄在线观看动漫尤物| 国产jizzjizz视频免费看| 日本亚洲免费无线码| baoyu116.永久免费视频| 最新亚洲人成无码网站| 亚洲一区二区三区久久| 亚洲人成网站影音先锋播放| 亚洲综合激情另类专区| 国产精品另类激情久久久免费| 久久久久久国产精品免费无码 | 中文字幕免费在线看电影大全| tom影院亚洲国产一区二区| 亚洲国产精品成人久久| 亚洲精品无码99在线观看| 无码高潮少妇毛多水多水免费| aⅴ在线免费观看|