JEE中文乱码问题的原理和解决方法汇总

来源:互联网 发布:分布式数据库实现 编辑:程序博客网 时间:2024/05/20 02:27
转载于:http://www.jeecms.com/news/804_2.htm
摘 要: 感谢网友们一直以来对jeecms的关注和支持,我们在jeecms使用交流群里经常看到网友反映乱码问题,在JEE开发中,乱码确实是一个令人头痛的问题,相信大家都遇到过,今天我们就这个问题总结一下,希望能帮助大家更好的解决JEE开发中的乱码问题。

 

     感谢网友们一直以来对jeecms的关注和支持,我们在jeecms使用交流群里经常看到网友反映乱码问题,在JEE开发中,乱码确实是一个令人头痛的问题,相信大家都遇到过,今天我们就这个问题总结一下,希望能帮助大家更好的解决JEE开发中的乱码问题。

      我们知道产生乱码的原因是因为不同的编码造成的,这就好比你和一个印地安人在说话,假设你完全不懂印第安语,而对方也不懂汉语,那你们所说的话,就会在对方的脑子里产生一个个的问号。那么怎么办呢?通常的做法,就是找一个翻译,在Java中,对编码也是这样的,    在这我把在JEE开发中遇到的中文乱码的问题及解决办法写出来供大家参考。常见的乱码问题主要体现在以下几方面:

一、页面显示乱码

二、表单提交中文时出现乱码

三、数据库连接时出现乱码

四、数据库的显示乱码

 

 

一、页面显示乱码

    下面的显示页面(display.jsp)就出现乱码:


<html>
<head>
<title>JEE的中文处理</title>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
</head>

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

    对不同的WEB服务器和不同的JDK版本,处理结果就不一样。原因:服务器使用的编码方式不同和浏览器对不同的字符显示结果不同而导致的。解决办法:在JSP页面中指定编码方式(gb2312),即在页面的第一行加上: 英文代码<%@ page contentType="text/html; charset=gb2312"%>就可以消除乱码了。(注:GBK的范围大于GB2312 ,GB2312仅指简体中文,而GBK不仅指简体中文,还包含了繁体中文等中文。)

    完整页面如下:


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

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

 

 

 

二、表单提交中文时出现乱码

    下面是一个提交页面(submit.jsp),代码如下:


<html>
<head>
<title>JEE的中文处理</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>JEE的中文处理</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>JEE的中文处理</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 String iso2gb(String qs)
{
try{
if (qs == null) return "NULL";
else
{
return new String(qs.getBytes("iso-8859-1"),"gb2312");
}
}
catch(Exception e){
System.err.println("iso2gb error:"+e.getMessage());
}
return "NULL";
}

public String gb2iso(String qs)
{
try
{
if (qs == null) return "NULL";
else {
return new String(qs.getBytes("gb2312"),"iso-8859-1"); }
}
catch(Exception e){ System.err.println("gb2iso error:"+e.getMessage());}
return "NULL";
}
 
    字符存入数据库时用 gb2iso()函数,将字符从数据库取出时,再用 iso2gb()函数。

原创粉丝点击