科技行者

行者学院 转型私董会 科技行者专题报道 网红大战科技行者

知识库

知识库 安全导航

至顶网软件频道J2EE基础 如何解决JSP页面显示乱码问题

J2EE基础 如何解决JSP页面显示乱码问题

  • 扫一扫
    分享文章到微信

  • 扫一扫
    关注官方公众号
    至顶头条

J2EE基础 如何解决JSP页面显示乱码问题

作者:dxaw 来源:赛迪网技术社区 2007年11月24日

关键字: 显示乱码 JSP J2EE

  • 评论
  • 分享微博
  • 分享邮件

一、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 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()函数。

查看本文来源
    • 评论
    • 分享微博
    • 分享邮件
    邮件订阅

    如果您非常迫切的想了解IT领域最新产品与技术信息,那么订阅至顶网技术邮件将是您的最佳途径之一。

    重磅专题
    往期文章
    最新文章