发表于: java/j2ee | 作者: | 日期: 2010/1/18 01:01

大家在JSP的开发过程中,经常出现中文乱码的问题,可能一至困扰着您,我现在把我在JSP开发中遇到的中文乱码的问题及解决办法写出来供大家参考。

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



JSP的中文处理


<% out.print("JSP的中文处理"); %>


对不同的WEB服务器和不同的JDK版本,处理结果就不一样。原因:服务器使用的编码方式不同和浏览器对不同的字符显示结果不同而导致的。解决办法:在JSP页面中指定编码方式(gb2312),即在页面的第一行加上:


<%@ page contentType="text/html; charset=gb2312"%>

就可以消除乱码了。完整页面如下:


<%@ page contentType="text/html; charset=gb2312"%>


JSP的中文处理


<% out.print("JSP的中文处理"); %>


二、表单提交中文时出现乱码
下面是一个提交页面(submit.jsp),代码如下:




JSP的中文处理




下面是处理页面(process.jsp)代码:


<%@ page contentType="text/html; charset=gb2312"%>


JSP的中文处理


<%=request.getParameter("name")%>


submit.jsp提交英文字符能正确显示,但是提交中文时就会出现乱码。原因:浏览器默认使用UTF-8编码方式来发送请求,而UTF- 8和GB2312编码方式表示字符时不一样,这样就出现了不能识别字符。(另外的一种说法是:tomcat的内部编码格式为iso8859-1,也就是说post提交时,如果没有设置提交的编码格式,则会以iso8859-1方式进行提交,接受的jsp却以utf-8的方式接受。导致乱码。)

解决办法:通过request.seCharacterEncoding (“gb2312”)对请求进行统一编码,就实现了中文的正常显示。修改后的process.jsp代码如下:


<%@ page contentType="text/html; charset=gb2312"%>
<% request.seCharacterEncoding("gb2312"); %>


JSP的中文处理


<%=request.getParameter("name")%>


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

示例:

String Url=”jdbc:mysql://localhost/digitgulf?user=root&password=root&useUnicode=true&characterEncoding=GB2312″;

四、数据库的显示乱码
在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()来转换编码。

整理自网络

: https://blog.darkmi.com/2010/01/18/1045.html

本文相关评论 - 才一条评论
hueocme
2010-09-30 10:41:45

嗯,这个总结的挺好的,但是在提交的时候可以对提交的url串中的字符集转码的啊

Sorry, the comment form is closed at this time.