J2EE SQL Server中文亂碼問題解讀方法
J2EE 帶動了Java在企業級的發展,但隨着一些輕量級組件的出現,J2EE的臃腫和開發難度高的缺點越來越引起了許多人的注意,EJB2.0也被許多人稱爲累贅。下面是小編整理的關於J2EE SQL Server中文亂碼問題解讀方法,歡迎大家參考!
一、Java中文問題的由來
Java的內核和class文件是基於unicode的,這使Java程序具有良好的跨平臺性,但也帶來了一些中文亂碼問題的麻煩。原因主要有兩方面,Java和JSP文件本身編譯時產生的亂碼問題和Java程序於其他媒介交互產生的亂碼問題。
首先Java(包括JSP)源文件中很可能包含有中文,而Java和JSP源文件的保存方式是基於字節流的,如果Java和JSP編譯成class文件過程中,使用的編碼方式與源文件的編碼不一致,就會出現亂碼。基於這種亂碼,建議在Java文件中儘量不要寫中文(註釋部分不參與編譯,寫中文沒關係),如果必須寫的話,儘量手動帶參數-ecoding GBK或-ecoding gb2312編譯;對於JSP,在文件頭加上<%@ page contentType="text/html;charset=GBK"%>或<%@ page contentType="text/html;charset=gb2312"%>基本上就能解決這類亂碼問題。
本文要重點討論的是第二類亂碼,即Java程序與其他存儲媒介交互時產生的亂碼。很多存儲媒介,如數據庫,文件,流等的存儲方式都是基於字節流的,Java程序與這些媒介交互時就會發生字符(char)與字節(byte)之間的轉換,例如從頁面提交表單中提交的數據在Java程序裏顯示亂碼等情況。
如果在以上轉換過程中使用的編碼方式與字節原有的編碼不一致,很可能就會出現亂碼。
二、解決方法
對於流行的Tomcat來說,有以下兩種解決方法:
1) 更改 D:Tomcatconf,指定瀏覽器的編碼格式爲“簡體中文”:
方法是找到 中的
enableLookups="false" redirectPort="8443" acceptCount="100"
connectionTimeout="20000" disableUploadTimeout="true" URIEncoding='GBK' />
標記,粗體字是我添加的'。
可以這樣驗證你的更改是否成功:在更改前,在你出現亂碼的頁面的IE瀏覽器,點擊菜單“查看|編碼”,會發現“西歐(ISO)”處於選中狀態。而更改後,點擊菜單“查看|編碼”,會發現“簡體中文(GB2312)”處於選中狀態。
b)更該 Java 程序,我的程序是這樣的:
public class ThreeParams extends HttpServlet {
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
ontentType("text/html; charset=GBK");
...
}
}
粗體字是必需要有的,它的作用是讓瀏覽器把Unicode字符轉換爲GBK字符。這樣頁面的內容和瀏覽器的顯示模式都設成了GBK,就不會亂碼了。
相關文章
-
j2ee培訓:如何構建RESTful Web Service
JavaEE的核心是EJB3.0, 其提供了更兼便捷的企業級的應用框架。下面yjbys小編爲大家準備了關於如何構建RESTful Web Service的.文章,歡迎閱讀。 1. 首先是實體類,注意其中的@XmlRootElement註解package s;import ;imp -
如何將Session值儲存於SQL Server中呢
一般情況下,我們喜歡使用Session儲存我們的變量。提供了下面一些方法儲存Session的值:InProcStateServerSQLServer“InProc”表示我們使用傳統ASP一樣的方法儲存Session的值,而且“StateServer”則表示使用另外一臺主機 -
Sql Server、Access數據排名的實現方法
但是,在SQL SERVER 2005 之前,SQL SERVER 2000 並沒有提供這個直接的.函數供我們使用,同樣 ACCESS 也是如此。下面我們分2種情況,來寫出數據排名的實現過程。測試數據如下:Access複製代碼 代碼如下:select name, score, (s -
SQL Server無法連接解決方案
SQL Server無法連接究竟應該如何解決呢?提示"無法連接到服務器,用戶xxx登陸失敗" 是因爲什麼原因呢?下面是由本站小編爲大家準備的SQL Server無法連接解決方案,喜歡的可以收藏一下!瞭解更多詳情資訊,請關注應屆畢業生考 -
MS SQL Server Management Studio Express安裝圖文具體步驟
Microsoft sql server Management Studio Express (SSMSE) 是一種免費、易用的圖形管理工具,用於管理 SQL Server 2005 Express Edition 和具有高級服務的 SQL Server 2005 Express Edition。SSMSE 還可以管理任何版本 -
SQLServer導出sql文件/表架構和數據操作方法
很多朋友問到sql server數據庫”生成腳本”,只導出了數據庫的sql腳本,而表裏的數據依然沒有導出來。很簡單,看教程:注:我這裏用的SQLServer2008,其它版本應該差不多。一、選中要導出的`數據庫–>任務–>生成腳本(或者在任務 -
sql server中避免死鎖的方法
武則天爲什麼被李世民冷落12年?武則天從13歲進宮當才人,到25歲也就是李世民逝世的時候,還是個才人,且從未生育過李世民的子嗣。這足以說明,李世民並不重用她。“李世民,是唐朝第二位皇帝,他名字的意思是“濟世安民”。漢族,隴 -
三級數據庫:在SQLSERVER中實現RSA加密算法
爲了使廣大考生在備戰計算機等級考試時,更快的掌握相應知識點,下面是小編搜索整理的三級數據庫:在SQLSERVER中實現RSA加密算法,供參考練習,預祝考生們考出自己理想的成績!/*本次修改增加了unicode的支持,但是加密後依然顯示 -
Servlet/JSP相關問題解答
1 什麼是JSP?它和Servlet有什麼區別?答:你可以將JSP當做一個可擴充的HTML來對待。雖然在本質上JSP文件會被服務器自動翻譯爲相應的Servlet來執行。可以說Servlet是面向Java程序員而JSP是面向HTML程序員的,除此之外 -
如何用JSP連接SQLServer數據庫
Java基礎用JSP連接SQLServer數據庫,是我們在日常中經常用到的'。下面YJBYS小編爲大家整理了具體的用法,希望對你有所幫助。,,複製到tomcat目錄\common\lib\環境設置:jdbc驅動程序,,複製到tomcat目錄\common\lib\2.設