在J2EE中,乱码问题是一个令人头痛的问题,相信大家都遇到过,今天我们就这个问题总结一下,希望能帮到大家更好的解决J2EE中的乱码问题。
首先,我们知道产生乱码的原因是因为不同的编码造成的,这就好比你和一个印地安人在说话,假设你完全不懂印第安语,而对方也不懂汉语,那你们所说的话,就会在对方的脑子里产生一个个的问号。那么怎么办呢?通常的做法,就是找一个翻译,在Java中,对编码也是这样的,来看一个例子方法一:
1
2
3
7
8 这是一个简单的提交页面Deom01.html
<%@page contentType="text/html;charset=gbk" %>
输入内容为:<%=request.getParameter("uname")%>
以上是一个对Deom01.html进行处理的JSP页面,其作用是为了取出Demo01的Uname值并显示,
输入内容为:
当我们在页面Deom01中输入中文并提交好,发现提交后的显示内容为“?”号,这里,就相当于上面的不同语种的人说话一样,产生了“?”号,那么解决的办法,就是通过转换来解决这一问题:
<%@page contentType="text/html;charset=gbk" %>
<%
/**//*String name=request.getParmaeter("uname");//取得uname的值
byte[] b=name.getBytes("ISO8859-1");//将取得的值转换为Byte数组
name=new String(b);//将Byte数组重新转换为所需要的格式
*/
String name=new String(request.getParameter("uname").getBytes("ISO8859-1"));//这里等同于上面
%>
输入内容为:<%=uname%>
<%-- 输入内容为:<%=request.getParameter("uname")%>
--%>
以上通过将取得的uname值转换为Byte数组,再将Byte数组转换为所需要的格式来进行转换,从而解决了乱码问题。
方法二:设置统一的字符编码在API中的Javax.servlet.http包下,有一个HttpServletRequest接口中,有这样一个方法
public void setCharacterEncoding(String env)
throws UnsupportedEncoding
其作用是设置统一的字符编码
<%@page contentType="text/html;charset=gbk" %>
<%
/**//*String name=request.getParmaeter("uname");//取得uname的值
byte[] b=name.getBytes("ISO8859-1");//将取得的值转换为Byte数组
name=new String(b);//将Byte数组重新转换为所需要的格式
*/
//String name=new String(request.getParameter("uname").getBytes("ISO8859-1"));//这里等同于上面
request.setCharacterEncoding("GBK");
String name=request.getParameter("uname");
%>
输入内容为:<%=name%>
<%-- 输入内容为:<%=request.getParameter("uname")%>
--%>
更改后运行,发现结果和以前的一样。
(注:GBK的范围大于GB2312 ,GB2312仅指简体中文,而GBK不仅指简体中文,还包含了繁体中文等中文。)
本文作者:佚名 来源:本站原创
CIO之家 www.ciozj.com 微信公众号:imciow