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