您的位置:首页 > 数据库

JSP中乱码问题解决(一、JSP页面显示乱码,二、表单提交中文时出现乱码,三、数据库连接出现乱码,四、数据库的显示乱码 )

2007-06-01 23:21 1231 查看
http://blog.csdn.net/cnzll/archive/2005/12/30/558037.aspx

一、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.setCharacterEncoding("gb2312")对请求进行统一编码,就实现了中文的正常显示。

修改后的process.jsp代码如下:
<%@ page contentType="text/html; charset=gb2312"%>
<%
request.setCharacterEncoding("gb2312");
%>
<html>
<head>
<title>JSP的中文处理</title>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
</head>

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

可以使用如下方式解决乱码:

在获取变量时候,使用
String userid=new String(request.getParameter("userid").getBytes("ISO8859_1"),"GBK");

userid是提交过来的变量名

三、数据库连接出现乱码

只要涉及中文的地方全部是乱码,解决办法:在数据库的数据库URL中加上useUnicode=true&characterEncoding=GBK就OK了。

例:

写在JAVA代码中,直接这样写:
假设我新建的数据库是testdb,那么我连接数据库的url应该为:
jdbc:mysql://localhost:3306/testdb?useUnicode=true&characterEncoding=gbk

但如果是在xml配置文件中(如struts-config.xml,web.xml等),要把其中的&改为&才行,否则会出错。
jdbc:mysql://localhost:3306/testdb?useUnicode=true&characterEncoding=gbk

四、数据库的显示乱码
在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中的乱码问题解决方案
(以下浏览器均为IE,服务器为tomcat)

服务器发送页面给浏览器时有两个地方指定encoding
一处是在http应答的header里
一处是在html文档里

1、http头设置编码
若在jsp中request.setContentType("text/html; encoding=gb2312");这就明确告诉浏览器这篇文档是gb2312编码的,浏览器不作任何转换,只是以gb2312来显示。若文档中有8859_1编码的字串,将会出现乱码。

若jsp中干脆就没有setContentType,服务器会把http头的中的编码设为8859_1,浏览器通过http头就认为这篇文档是8859_1编码的(而不管文档真正的编码是什么),会以8859_1来显示。若文档中有8859_1编码的中文字串,只要手动调整浏览器的encoding到gb2312,浏览器会做一个8859_1到gb2312的转换,并以gb2312来显示,你会看到正确的文字。但这样每次都要手动来改变浏览器的encoding很麻烦。

2、在html文档中设置编码
要让html文档中设置的编码有效,必须把http头中的编码设为空。上文说过,如果jsp中没有setContentType,服务器会把http头的中的编码设为8859_1,这样一来,浏览器还是只认http头中设置的编码而不认html文档中设的编码。

体会:整篇文档的encoding必须一致.

服务器发送页面给浏览器时有两个地方指定encoding
一处是在http应答的header里
一处是在html文档里
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: