JSP中contentType的charset和pageEncoding區別|編程程序
06-19
JSP中contentType的charset和pageEncoding區別發表於:2010-04-22 03:35 | 點擊:217 次 | 標籤 : 類型 二〇一〇年四月十九日 21:23:04 下午和女朋友去吃了點飯,之後在操場溜達了兩圈,送回去了她,我在自己組的房子裡面開始看JSP的教程了,上午學習了一下request,打算看一下另一個內置對象response. 看第一個參數的介紹contentType 就發矇。 ContentType 屬性指定響應的 HTTP 內容類型。如果未指定 ContentType,默認為 text/HTML。語法 Response.ContentType = "ContentType" "ContentType" (描述內容類型的字元串。該字元串通常被格式化為類型/子類型,其中類型是常規內容範疇而子類為特定內容類型) 一句話總結就是,伺服器響應客戶端是以"ContentType" 的類型來響應的。這個很容易理解,但是在百度百科裡面看了一下發現問題了,在contenttype裡面有一個屬性是charset 指定編碼的,而pagEncoding也是編碼的,這兩個編碼有什麼區別呢? 查閱了資料之後有了深刻的了解! pageEncoding是jsp文件本身的編碼 contentType的charset是指伺服器發送給客戶端時的內容編碼 JSP要經過兩次的"編碼",第一階段會用pageEncoding,第二階段會用utf-8至utf-8,第三階段就是由Tomcat出來的網頁, 用的是contentType 第一階段是jsp編譯成.java,它會根據pageEncoding的設定讀取jsp,結果是由指定的編碼方案翻譯成統一的UTF-8 JAVA源碼(即.java),如果pageEncoding設定錯了,或沒有設定,出來的就是中文亂碼。 第二階段是由JAVAC的JAVA源碼至java byteCode的編譯,不論JSP編寫時候用的是什麼編碼方案,經過這個階段的結果全部是UTF-8的encoding的java源碼。 JAVAC用UTF-8的encoding讀取java源碼,編譯成UTF-8 encoding的二進位碼(即.class),這是JVM對常數字串在二進位碼(java encoding)內表達的規範。 第三階段是Tomcat(或其的application container)載入和執行階段二的來的JAVA二進位碼,輸出的結果,也就是在客戶端見到的,這時隱藏在階段一和階段二的參數contentType就發揮了功效 contentType的設定. pageEncoding 和contentType的預設都是 ISO8859-1. 而隨便設定了其中一個, 另一個就跟著一樣了(TOMCAT4.1.27是如此). 但這不是絕對的, 這要看各自JSPC的處理方式. 而pageEncoding不等於contentType, <%@ page contentType="text/html;charset=utf-8" %> 記得老師上課講的時候遇到了下面這種情況 他的處理辦法是把utf-8改成了gbk, <%@ page contentType="text/html;charset=gbk" %> 貌似就是利用了隨便改變其中一個另一個就跟著變的原理吧。實際上正規的該法應該是 <%@ page contentType="text/html;charset=utf-8" pageEncoding="GBK"%> 但是如果改成了這樣,在伺服器端收到的獲取的中文不是亂碼,但是在客戶端打開的還是亂碼,因為charset=utf-8" 中charset指定了,輸出到客戶端的是utf-8的編碼,所以想正規的該法應該改成 <%@ page contentType="text/html;charset=gbk" pageEncoding="GBK"%> 貌似這樣寫,還不如 <%@ page contentType="text/html;charset=gbk" %> 簡單呢, 看來以後自己還是用 這種簡單的寫法吧! 純屬個人自學的理解。如果錯誤還望指出
推薦閱讀:
推薦閱讀:
※白茶種類有哪些?如何區別它們
※黃龍玉和黃蠟石區別
※大乘佛教和小乘佛教的最大區別到底是什麼?
※草莓、茅莓、蛇莓、覆盆子的區別 |茅莓和覆盆子|茅莓和覆盆子的區別|植物與應用|討論平台
※信佛與學佛的區別