摘要:Java
EE开发中经常会遇到一些乱码问题,这使开发者不胜其烦。本文为大家介绍两种解决Java EE乱码问题的方法,简单、便捷,希望能给Java
EE开发者一些启发。
首先,我们知道产生乱码的原因是因为不同的编码造成的,这就好比你和一个印地安人在说话,假设你完全不懂印第安语,而对方也不懂汉语,那你们所说的话,就会在对方的脑子里产生一个个的问号。那么怎么办呢?通常的做法,就是找一个翻译,在Java中,对编码也是这样的,来看一个例子。
方法一:
- <html>
- <body>
- <form action="demo02.jsp" method="post">
- 用户名:<input type="text" name="uname">
- <input type="submit" value="go">
- </form>
- </body>
- </html>这是一个简单的提交页面Deom01.html
- <%@page contentType="text/html;charset=gbk" %>
- <html>
- <body><h1>输入内容为:<%=request.getParameter("uname")%></h1>
- </body>
- </html>
|
以上是一个对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不仅指简体中文,还包含了繁体中文等中文。)
以上仅仅是我们总结出来的两个解决乱码问题两个办法,针对不同问题还需要不同的办法,希望大家集思广益,找到症结,对症下药!
|