1.以POST方法提交的表单数据中有中文字符
由于WEB容器默认的编码方式是ISO-8859-1,在servlet/JSP程序中,通过请求对象的getParameter()方法得到的字符串是以ISO-8859-1转换而来,这是导致乱码产生的原因之一。为了避免容器以ISO-8859-1的编码方式返回字符串,对于以POST方法提交的表单数据,可以在获取请求参数值之前,调用request.setCharaterEncoding("GBK"),明确指定请求正文使用的字符编码方式是GBK。在向浏览器发送中文数据之前,调用response.setContentType("text/html;charset=GBK"),指定输出内容的编码方式是GBK。
为了指定输出内容的编码方式,设置page指令contentType属性如下:
<%@ page contentType="text/html;charset=GBK"%>
2.以GET方法提交的表单数据中有中文字符
当提交表单采用GET方式时,提交的数据作为查询字符串或者是所谓的传参被附加到URL的末端,发送到服务器,此时在服务器端调用setCharaterEncoding("GBK")方法也就没有作用了。我们需要在得到请求参数的值后,自己做正确的编码转换。
String name=request.getParameter("name");
name=new String(name.getBytes("ISO-8859-1"),"GBK");
在第一行,调用getParameter()方法得到的字符串name的Unicode值是以ISO-8859-1编码转换而来,调用name.getBytes("ISO-8859-1"),将得到原始的GBK编码值,接着,对new String()的调用将以GBK字符集重新构造字符串的Unicode编码。
为了方便从ISO-8859-1编码到GBK编码的转换,我们可以编写一个工具方法,如下:
public String toGBK(String str) throws java.io.UnsupportedEncodingException{
return new String(str.getBytes("ISO-8859-1"),"GBK");
}
3.在数据库中存储和读取中文数据
对于大多数数据库的JDBC驱动程序,在Java程序和数据库之间传递数据都是以ISO-8859-1为默认编码格式,所以我们在程序中向数据库存储包含中文的数据时,JDBC驱动程序首先把程序内部的Unicode编码格式的数据转换为ISO-8859-1编码,然后传递到数据库中;在数据库保存数据时,默认即以ISO-8859-1保存,这就是为什么我们经常在数据库中读取中文数据时,读到的是乱码。
要解决上述问题,只需将数据库默认的编码格式改为GBK或GB2312即可,不同的数据库还提供了另外的方式来处理字符编码转换的问题,在实际应用中,可以针对具体情况再做具体处理,只要理解编码转换的过程,就能找到问题的所在,进而解决问题。
4.Servlet/JSP在不同语言系统的平台下运行
有些时候,我们在中文系统卡法平台下开发的Web应用程序移植到英文系统平台下,在Servlet和JSP中直接书写的中文字符串在输出时,将显示为乱码。这是因为在编译Servlet类或者JSP文件时,如果没有使用-encoding参数指定Java源程序的编码格式,javac会获取本地操作系统默认采用的字符集,以该字符集将Java源程序转换为Unicode编码保存到内存中,然后将源程序便以为字节码文件(字节码文件采用的是utf-8编码),保存到硬盘上。
在英文平台下,采用的默认编码格式是ISO-8859-1,所以在编译转换后,执行输出时,原先在源文件中书写的中文字符串就变成了乱码。
要解决这个问题,在编译Servlet类的源程序时,可以使用-encoding参数指定编码为GBK或者GB2312,例如:
javac -encoding GBK HelloServlet.java
对于JSP页面,只要在page指令中用contentType属性或pageEncoding属性指定编码格式为GBK或GB2312,Web容器就可以正确转换和编译JSP文件了。例如:
<%@ page contentType="text/html;charset=GBK"%>或者<%@ page pageEncoding="GBK"%>
5.使用过滤器解决中文问题 详情见工程TestFilter
(1)首先使用eclipse新建一个名为TestFilter的Dynamic Web Project
(2)在WEB-INF文件夹下新建classes,并在Java Build Path中的Source中将Default output folder改为此classes的路径。
(3)导包servlet.jar
(4)编写网页index.html test.jsp
(5)编写servlet和过滤器类TestServlet.java和EncodingFilter.java放在什么包下是个人的事情(src下建包)。
(6)配置WEB-INF下的web.xml文件。
(7)说明:在EncodingFilter.java中有两句代码:
request.setCharacterEncoding(encoding); //接收之前转码
response.setContentType("text/html;charset="+encoding);//写页面之前转码
(8)如果将本工程中表单提交方式改为get或者url传值中带中文将会出现乱码的,怎么改见上文。
(9)如何指定URL编码:在tomcat的conf文件夹下找到server.xml,修改connector元素,在它的最后加上URIEncoding="gb2312"。
评论0
最新资源