jsp頁面之間,資料庫·······亂碼問題

來源:互聯網
上載者:User

一、JSP頁面顯示亂碼

二、表單提交中文時出現亂碼

三、資料庫連接

大家在JSP的開發過程中,經常出現中文亂碼的問題,可能一至困擾著您,我現在把我在JSP開發中遇到

的中文亂碼的問題及解決辦法寫出來供大家參考。

一、JSP頁面顯示亂碼
下面的顯示頁面(display.jsp)就出現亂碼:
<html>
<head>
<title>JSP的中文處理</title>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
</head>

<body>
<%
out.print("JSP的中文處理");
%>
</body>
</html>
對不同的WEB伺服器和不同的JDK版本,處理結果就不一樣。原因:伺服器使用的編碼方式不同和瀏覽器

對不同的字元顯示結果不同而導致的。解決辦法:在JSP頁面中指定編碼方式(gb2312),即在頁面的第一

行加上:<%@ page contentType="text/html; charset=gb2312"%>,就可以消除亂碼了。完整頁面如下


<%@ page contentType="text/html; charset=gb2312"%>
<html>
<head>
<title>JSP的中文處理</title>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
</head>

<body>
<%
out.print("JSP的中文處理");
%>
</body>
</html>

二、表單提交中文時出現亂碼
下面是一個提交頁面(submit.jsp),代碼如下:
<html>
<head>
<title>JSP的中文處理</title>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
</head>

<body>
<form name="form1" method="post" action="process.jsp">
<div align="center">
<input type="text" name="name">
<input type="submit" name="Submit" value="Submit">
</div>
</form>
</body>
</html>
下面是處理頁面(process.jsp)代碼:
<%@ page contentType="text/html; charset=gb2312"%>
<html>
<head>
<title>JSP的中文處理</title>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
</head>

<body>
<%=request.getParameter("name")%>
</body>
</html>
如果submit.jsp提交英文字元能正確顯示,如果提交中文時就會出現亂碼。原因:瀏覽器預設使用UTF

-8編碼方式來發送請求,而UTF- 8和GB2312編碼方式表示字元時不一樣,這樣就出現了不能識別字元。

解決辦法:通過request.seCharacterEncoding ("gb2312")對請求進行統一編碼,就實現了中文的正常

顯示。修改後的process.jsp代碼如下:
<%@ page contentType="text/html; charset=gb2312"%>
<%
request.seCharacterEncoding("gb2312");
%>
<html>
<head>
<title>JSP的中文處理</title>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
</head>

<body>
<%=request.getParameter("name")%>
</body>
</html>

三、資料庫連接出現亂碼
只要涉及中文的地方全部是亂碼,解決辦法:在資料庫的資料庫URL中加上
useUnicode=true&characterEncoding=GBK 就OK了。

四、資料庫的顯示亂碼
在mysql4.1.0中,varchar類型,text類型就會出現中文亂碼,對於varchar類型把它設為binary屬性就

可以解決中文問題,對於text類型就要用一個編碼轉換類來處理,實現如下:
public class Convert {
/** 把ISO-8859-1碼轉換成GB2312
*/
public static String ISOtoGB(String iso){
String gb;
try{
if(iso.equals("") || iso == null){
return "";
}
else{
iso = iso.trim();
gb = new String(iso.getBytes("ISO-8859-1"),"GB2312");
return gb;
}
}
catch(Exception e){
System.err.print("編碼轉換錯誤:"+e.getMessage());
return "";
}
}
}
把它編譯成class,就可以調用Convert類的靜態方法ISOtoGB()來轉換編碼。


如果你還有什麼不懂之處:我給大家推薦一個好的JSP-JAVA網站:

http://www.phy.hbnu.edu.cn/dsp/


總結:

1. 在jsp中<%@ page contentType="text/html; charset=A" %>如果指定了,那麼在改jsp中所有構造

的String(不是引用),如果沒有指定編碼,那麼這些String的編碼是A的。
從request的得到的String如果沒有指定request的編碼的話,他是iso-8859-1的
從別的地方得到的String是使用原來初始的編碼的,比如從資料庫得到String,如果資料庫的編碼

是B,那麼該String的編碼是B而不是A的,也不是系統預設的。
此時,如果要輸出的String的編碼不是A,那麼,很可能顯示亂碼的,所以首先要將String正確轉化

為編碼A的String,然後輸出。

2. 在jsp中<%@ page contentType="text/html; charset=A" %>沒有指定,那麼相當於指定了<%@

page contentType="text/html; charset=ISO-8859-1" %>

3. Servelte中如果執行了像 response.setContentType("text/html;charset=A");説明將response的

字元輸出資料流編碼設定為A,所有要輸出的String的編碼要轉化為A的,否則會得到亂碼的。
Servelet中從request得到的String的編碼和jsp中一樣的,但是在servlet java檔案中構造的

String是使用的系統預設的編碼的。在servelt中從外部得到的String 是使用原來的編碼的,比如從編

碼為B的資料庫得到的資料是編碼為B的,不是A,也不是系統預設的編碼。

在使用JSP的過程中,最使人頭疼的一個問題就是中文亂碼問題,以下是我在軟體開發中遇到的亂

碼問題以及解決方案。

1、JSP頁面亂碼 
  這種亂碼的原因是應為沒有在頁面裡指定使用的字元集編碼,解決方案:只要在頁面開始地方用下

面代碼指定字元集編碼即可,

2、資料庫亂碼 
  這種亂碼會使你插入資料庫的中文變成亂碼,或者讀出顯示時也是亂碼,解決方案如下: 
  在資料庫連接字串中加入編碼字元集 
  String Url="jdbc:mysql://localhost/digitgulf?

user=root&password=root&useUnicode=true&characterEncoding=GB2312"; 
  並在頁面中使用如下代碼: 
  response.setContentType("text/html;charset=gb2312"); 
  request.setCharacterEncoding("gb2312");

3、中文作為參數傳遞亂碼 
  當我們把一段中文字元作為參數傳遞個另一頁面時,也會出現亂碼情況,解決方案如下: 
  在參數傳遞時對參數編碼,比如 
  RearshRes.jsp?keywords=" + java.net.URLEncoder.encode(keywords) 
  然後在接收參數頁面使用如下語句接收 
  keywords=new String(request.getParameter("keywords").getBytes("8859_1"));

4、JSP頁面亂碼加這句 
<%@ page contentType="text/html; charset=gb2312" language="java" import="java.sql.*"

errorPage="err.jsp" %>

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.