當使用JSP頁面將中文數據添加到MySql數據庫中的時候發現變為亂碼,或者從mysql中讀取中文的時候出現亂碼,這些問題根源都是由于字符編碼不一致造成的。要知道病源是什么我們才能對癥下藥,所以我將問題產生的過程簡單描述一下(如有不對望高人賜教)
我們以一個從form表單讀取數據并寫入mysql數據庫的例子來講解;
HTML頁面參數―(以瀏覽器的編碼方式發送)―》JSP頁面―(以JSP定義的編碼方式被編譯)―》被JSP引擎編譯為*.class文件――》在JSP容器中運行――》傳遞給Mysql數據庫―(以數據庫的編碼方式讀取數據并存儲)―》讀取Mysql―(以數據庫的編碼方式讀取)―》JSP頁面接受后在瀏覽器中顯示(以瀏覽器編碼方式解碼顯示);
注意:這里的“瀏覽器編碼”“JSP頁面編碼”“JSP頁面輸出編碼”“JSP頁面輸入編碼”“數據庫的編碼”可能存在潛在的不一直,當它們中的任意一個不相同的時候就會出現亂碼;就好像傳話游戲一樣,張三要把話傳給李四,李四把他聽到的傳給王五,要讓王五知道張三說的什么就需要他們三個人使用的相同語言,如果李四是個火星人,他當然聽不懂張三說什么,然后他還不厚道的對王五說火星話(亂碼),結果王五就只能聽到亂碼了。(比喻比較汗~~^_^!)
jsp中文亂碼 jsp mysql 亂碼要servlet里面支持中文的方法:
在dopost或者doget的第一句加上:
request.setCharacterEncoding("GB2312"); response.setCharacterEncoding("GB2312");
jsp亂碼問題在jsp里面就把
里設置成charset=gb2312
jsp頁面亂碼 jsp頁面中文亂碼 如果這樣還不行,就只有在取出中文后(getParameter)強制轉換了:
String str=new String(request.getParameter("text").getBytes("ISO-8859-1"),"GB2312");
很不錯的方法,因為在java里面,jsp數據庫亂碼是個大問題,jsp出現亂碼這些一定要銘記
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。
新聞熱點
疑難解答