JVM的默認編碼問題對JSTL標簽的影響

          Posted on 2006-03-02 11:17 么么茶 閱讀(11136) 評論(2)  編輯  收藏 所屬分類: JAVA-WEB

          今日無意中發(fā)現(xiàn)在中文系統(tǒng)使用良好的中文頁面在移植到英文系統(tǒng)后出現(xiàn)了亂碼,多方查找發(fā)現(xiàn),出現(xiàn)亂碼的頁面是使用的jstl標簽的c:url和c:param標簽生成的URL通過c:import嵌入網(wǎng)頁的,所以懷疑可能是c:param在進行Base64編碼是使用的編碼有問題。通過查找JSTL的源碼發(fā)現(xiàn)在org.apache.taglibs.standard.tag.common.core.ParamSupport類即c:param的實現(xiàn)類中有這樣一行代碼:

             parent.addParameter(URLEncoder.encode(name), URLEncoder.encode(value))

          其中URLEncoder.encode是問題所在。在JDK的API文檔中已經(jīng)標明URLEncoder.encode(String)這個方法已經(jīng)deprecated了,而應(yīng)該在編碼時指定編碼字符集。找到這里之后,再來看看URLEncoder.encode(String)的實現(xiàn):

             public static String encode(String s){
                String str = null;

                try {
                   str = encode(s, dfltEncName);
                } catch (UnsupportedEncodingException e) {
                }

                return str;
             }

          可以看到默認使用了dfltEncName的字符集,那么這個dfltEncName又是如何得到的呢?從源碼中找到如下:

             dfltEncName = (String) AccessController.doProivileged(new GetPropertyAction("file.encoding"))

          看到這里就一目了然了,JVM是從系統(tǒng)變量file.encoding中讀取了默認編碼的字符集。
          之后,寫了一個簡單的測試程序,分別從中英文系統(tǒng)中取了一次默認的字符集,中文沒問題是GBK,但是英文的就很奇怪,居然是Cp1252(好像是Latin I,按說應(yīng)該是ISO8859-1才是)。看了一下英文系統(tǒng)的區(qū)域設(shè)置,Location選的是Englist(United States),改成PRC就完事大吉了。
          為了防止這種問題的發(fā)生,最后還是決定采用最保險的辦法,在Tomcat的啟動參數(shù)中加入-Dfile.encoding=GBK,強制將缺省的字符集設(shè)為GBK,這樣就一勞永逸了。

          Feedback

          # re: JVM的默認編碼問題對JSTL標簽的影響  回復(fù)  更多評論   

          2007-06-21 01:55 by 海妖的夜
          非常感謝!很透徹的理解!

          # re: JVM的默認編碼問題對JSTL標簽的影響[未登錄]  回復(fù)  更多評論   

          2009-03-26 15:08 by Terry Lee
          有空試試UTF-8呀,我們做項目都要求用UTF-8,就是為了兼容各種語言,這是個國際通用的編碼,畢竟歐美和日韓都沒有用GBK編碼的

          只有注冊用戶登錄后才能發(fā)表評論。


          網(wǎng)站導(dǎo)航:
           
          主站蜘蛛池模板: 云霄县| 辽宁省| 昆明市| 教育| 天长市| 内丘县| 凯里市| 洪洞县| 广丰县| 和田县| 辽阳县| 成都市| 东源县| 天气| 乌什县| 天水市| 寿阳县| 文化| 民和| 广东省| 濮阳县| 永年县| 辽中县| 甘德县| 呼伦贝尔市| 汶上县| 永定县| 砀山县| 五家渠市| 四川省| 镇原县| 崇左市| 仙桃市| 满洲里市| 西畴县| 云安县| 吴堡县| 鞍山市| 赣榆县| 三台县| 通州区|