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

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

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

    posts - 495,  comments - 11,  trackbacks - 0

      1、Java編譯器在對源文件編譯前,會先把源文件轉換為unicode編碼,因為這個原因,我們在編譯時一定要把源文件用的是什么編碼方式正確無誤的”告訴”編譯器。

      例如:我們的源文件是以UTF-8的方式保存的,而在編譯時卻把它當作是用GBK方式保存的,這樣編譯器就會按照GBK->Unicode的編碼轉換方法對源文件進行轉換,然后再編譯,這樣當然會出錯,實際上編譯器應當按照UTF-8->Unicode的編碼轉換方法來對源文件進行轉換。

      a.對于控制臺程序,編譯器會把源文件看作是由系統默認的編碼類型來編碼的(系統默認的編碼類型取決于在控制面板區域設置里的配置,中文win2k下通常是GBK),也可以使用-encoding參數來設置,如:javac -encoding UTF-8,這樣編譯器就會把源文件看作是用UTF-8編碼的(這只是告訴編譯器源文件的編碼類型,而不是對源文件轉碼)。在各種語言的平臺上只要在編譯用時-encoding指定與源文件的編碼相同的編碼方式,就不會存在國際化的問題了。

      b.對于JSP,編譯器則會根據設定的字符集來判斷JSP文件使用的是什么編碼方式,進而將其轉換成unicode后進行編譯;若JSP中未指定,編譯器則會把JSP文件看作是按照系統默認的編碼來保存的。在JSP2.0里新增了一個指令來通知編譯器這個源文件所使用的編碼方式。

      2、在處理輸入輸出時,注意設置輸入流和輸出流的編碼類型與用戶輸入時和輸出設備顯示時采用的編碼方式一致。

      由于JRE在處理輸入輸出時會將輸入或輸出的內容進行編碼轉換,對于輸入會轉換為unicode后再送入,因此要正確的匹配實際輸入內容的編碼方式和告知JRE的編碼方式,對于輸出,會由unicode轉換為其他的編碼再送出程序,因此要正確匹配輸出設備顯示時用的編碼方式和告知JRE的編碼方式。

      例如:程序中設置輸入流的編碼是new InputStreamReader(System.in,"GB2312");而程序運行后用戶輸入時用了繁體中文的輸入法,輸入了BIG5編碼的內容,這樣JRE把BIG5編碼的內容當作GB2312的進行了GB2312->unicode的編碼轉換,這樣轉換后的結果顯然不是用戶想要輸入的內容了。

      默認情況下,JRE會把輸入輸出的內容當作是按照系統默認編碼方式編碼的。

      3、在Servlet中,除了一定要把源文件用的是什么編碼方式正確無誤的”告訴”編譯器外,還要注意實際提交的URL數據、表單數據的編碼格式和request中聲明的編碼格式一致。

      客戶端瀏覽器在通過表單和URL提交數據時,容器和JVM會將request中的數據看作是按照request所聲明的編碼方式來編碼的,將數據由這種編碼方式轉換為unicode后再送入servlet(實際上容器會先將request中的數據轉為一種中間編碼方式,具體根據容器的配置而定,再由JVM由這種中間方式轉換為unicode,通常這種中間格式是ISO)。servlet輸出的unicode數據會由容器根據response中聲明的編碼方式進行轉換,再送到客戶端瀏覽器上。

      在接收客戶端輸入時,用request.setCharacterEncoding()聲明請求中數據的編碼方式。

      在向客戶端輸出時用response.setContentType("text/html;charset=");聲明響應的數據的編碼方式,告知瀏覽器以哪種編碼方式顯示。

      4、在JSP中,由于JSP本就會被JSP編譯器編譯為servlet來運行,因此情況與servlet相同。

      這兩個JSP指令聲明了請求和響應的編碼方式。

      只要確保URL參數或表單中數據的編碼方式和所聲明的編碼方式一致,再通過告知JSP編譯器本JSP文件采用的編碼方式及含有哪種字符,即可解決JSP的字符編碼問題。

      這里是一個具體的例子:

      現在因為瀏覽器對UTF-8的支持,我們可以通過在源文件、請求、響應中都使用unicode編碼方式,來輕松達到處理國際化和字符編碼問題的目標。

      以我們使用的tomcat4.1.2為例,過程如下:

      1、編寫JSP頁面時:在每個JSP頁面在頁首都要增加一行:

      在編輯JSP頁面時,一定要確保JSP文件以unicode的方式保存,目前幾乎所有的編輯器都有以unicode編碼保存或將文件內容轉換成unicode的功能。

      2、增加一個用來聲明request的CharacterEncoding的類SetCharacterEncodingFilter.java;

      SetCharacterEncodingFilter的這個類主要的作用就是:把request在從頁面剛提交到server端的時候的encoding聲明為我們想要的encoding,通過調用request的方法setCharacterEncoding (String encoding) 來改變,這樣可以使request的從客戶端傳過來的時候,按我們在web.xml (在第二點可以講到) 中配置的encoding來對提交的數據編碼。

      3、修改web.xml文件,配置一個filter來過濾全部url請求,通過第二步中的類,聲明所有url請求的編碼類型未UTF-8。

      在web.xml文件中加上以下這段:

      

    posted on 2007-11-03 16:43 jadmin 閱讀(58) 評論(0)  編輯  收藏

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


    網站導航:
     
    主站蜘蛛池模板: 免费亚洲视频在线观看| 中文字幕乱码亚洲无线三区| 亚洲AV无码一区二区乱子伦| 亚洲国产精品无码久久久不卡| 亚洲日韩乱码中文无码蜜桃臀| 污视频网站免费在线观看| 无码精品国产一区二区三区免费 | 国产亚洲综合色就色| 456亚洲人成影院在线观| 免费在线观看亚洲| 亚洲Av无码乱码在线播放| 亚洲阿v天堂在线| 你懂得的在线观看免费视频| 成人免费毛片内射美女-百度| 四虎永久精品免费观看| 久久亚洲私人国产精品vA| 黄色毛片免费观看| 久久久久久久91精品免费观看| 国产亚洲美女精品久久久2020| 亚洲精品GV天堂无码男同| 无码成A毛片免费| 亚洲校园春色小说| 白白国产永久免费视频| 亚洲精品欧洲精品| 九九精品成人免费国产片| 免费国产在线观看不卡| 亚洲狠狠色丁香婷婷综合| 亚洲av高清在线观看一区二区 | 国精无码欧精品亚洲一区| 久久国产乱子伦精品免费看| 亚洲狠狠爱综合影院婷婷| 亚洲国产精华液2020| 国产亚洲精品免费视频播放| 人妖系列免费网站观看| 国产裸模视频免费区无码| 亚洲一区动漫卡通在线播放| 91老湿机福利免费体验| 亚洲AV无码一区二区二三区软件| 国产精品色拉拉免费看| 亚洲国产精品张柏芝在线观看| 亚洲一区免费在线观看|