JSP:我用的tomcat和eclipse jdk开发的时候,从数据库里读出数据 中文的电脑总是蓝屏乱码。求解方法!

声明:本文转自http://blog.csdn.net/youyue/article/details/4580402JAVA中文字符编码问题详解???JAVA的中文字符乱码问题一直很让人头疼。特别是在WEB应用中。网上的分析文章和解决方案都很多,但总是针对某些特定情况的。很多次遇到乱码问题后,经过极为辛苦的调试和搜索资料后终于解决,满以为自己已经掌握了对付这些字符乱码怪兽的诀窍。可当过段
声明:本文转自http://blog.csdn.net/youyue/article/details/4580402
JAVA中文字符编码问题详解
JAVA的中文字符乱码问题一直很让人头疼。特别是在WEB应用中。网上的分析文章和解决方案都很多,但总是针对某些特定情况的。很多次遇到乱码问题后,经过极为辛苦的调试和搜索资料后终于解决,满以为自己已经掌握了对付这些字符乱码怪兽的诀窍。可当过段时间,换了个应用或换了个环境,又会碰到那讨厌的火星文,并再次无所适从。于是下决心好好整理一下中文字符编码问题,以方便自己记忆,也为其他程序员兄弟们提供一份参考。 首先要了解JAVA处理字符的原理。JAVA使用UNICODE来存储字符数据,处理字符时通常有三个步骤: - 按指定的字符编码形式,从源输入流中读取字符数据 - 以UNICODE编码形式将字符数据存储在内存中 - 按指定的字符编码形式,将字符数据编码并写入目的输出流中。 所以JAVA处理字符时总是经过了两次编码转换,一次是从指定编码转换为UNICODE编码,一次是从UNICODE编码转换为指定编码。如果在读入时用错误的形式解码字符,则内存存储的是错误的UNICODE字符。而从最初文件中读出的字符数据,到最终在屏幕终端显示这些字符,期间经过了应用程序的多次转换。如果中间某次字符处理,用错误的编码方式解码了从输入流读取的字符数据,或用错误的编码方式将字符写入输出流,则下一个字符数据的接收者就会编解码出错,从而导致最终显示乱码。 这一点,是我们分析字符编码问题以及解决问题的指导思想。 好,现在我们开始一只只的解决这些乱码怪兽。 一、在JAVA文件中硬编码中文字符,在eclipse中运行,控制台输出了乱码。 例如,我们在JAVA文件中写入以下代码: String text = "大家好"; System.out.println(text); 如果我们是在eclipse里编译运行,可能看到的结果是类似这样的乱码:。那么,这是为什么呢? 我们先来看看整个字符的转换过程。 1. 在eclipse窗口中输入中文字符,并保存成UTF-8的JAVA文件。这里发生了多次字符编码转换。不过因为我们相信eclipse的正确性,所以我们不用分析其中的过程,只需要相信保存下的JAVA文件确实是UTF-8格式。 2. 在eclipse中编译运行此JAVA文件。这里有必要详细分析一下编译和运行时的字符编码转换。 - 编译:我们用javac编译JAVA文件时,javac不会智能到猜出你所要编译的文件是什么编码类型的,所以它需要指定读取文件所用的编码类型。默认javac使用平台缺省的字符编码类型来解析JAVA文件。平台缺省编码是操作系统决定的,我们使用的是中文操作系统,语言区域设置通常都是中国大陆,所以平台缺省编码类型通常是GBK。这个编码类型我们可以在JAVA中使用System.getProperty("file.encoding")来查看。所以javac会默认使用GBK来解析JAVA文件。如果我们要改变javac所用的编码类型,就要加上-encoding参数,如javac -encoding utf-8 Test.java。 这里要另外提一下的是eclipse使用的是内置的编译器,并不能添加参数,如果要为javac添加参数则建议使用ANT来编译。不过这并非出现乱码的原因,因为eclipse可以为每个JAVA文件设置字符编码类型,而内置编译器会根据此设置来编译JAVA文件。 - 运行:编译后字符数据会以UNICODE格式存入字节码文件中。然后eclipse会调用java命令来运行此字节码文件。因为字节码中的字符总是UNICODE格式,所以java读取字节码文件并没有编码转换过程。虚拟机读取文件后,字符数据便以UNICODE格式存储在内存中了。 3. 调用System.out.println来输出字符。这里又发生了字符编码转换。 System.out.println使用了PrintStream类来输出字符数据至控制台。PrintStream会使用平台缺省的编码方式来输出字符。我们的中文系统上缺省方式为GBK,所以内存中的UNICODE字符被转码成了GBK格式,并送到了操作系统的输出服务中。因为我们操作系统是中文系统,所以往终端显示设备上打印字符时使用的也是GBK编码。如果到这一步,我们的字符其实不再是GBK编码的话,终端就会显示出乱码。 那么,在eclipse运行带中文字符的JAVA文件,控制台显示了乱码,是在哪一步转换错误呢?我们一步步来分析。 - 保存JAVA文件成UTF-8后,如果再次打开你没有看到乱码,说明这步是正确的。 - 用eclipse本身来编译运行JAVA文件,应该没有问题。 - System.out.println会把内存中正确的UNICODE字符编码成GBK,然后发到eclipse的控制台去。等等,我们看到在Run Configuration对话框的Common标签里,控制台的字符编码被设置成了UTF-8!问题就在这里。System.out.println已经把字符编码成了GBK,而控制台仍然以UTF-8的格式读取字符,自然会出现乱码。 将控制台的字符编码设置为GBK,乱码问题解决。 (这里补充一点:eclipse的控制台编码是继承了workspace的设置的,通常控制台编码里没有GBK的选项而且不能输入。我们可以先在workspace的编码设置中输入GBK,然后在控制台的设置中就可以看到GBK的选项了,设置好后再把workspace的字符编码设置改回utf-8就是。)
二、JSP文件中硬编码中文字符,在浏览器上显示乱码。 我们用eclipse编写一个JSP页面,使用tomcat浏览这个页面时,整个页面的中文字符都是乱码。这是什么原因呢? JSP页面从编写到在浏览器上浏览,总共有四次字符编解码。 1. 以某种字符编码保存JSP文件 2. Tomcat以指定编码来读取JSP文件并编译 3. Tomcat向浏览器以指定编码来发送HTML内容 4. 浏览器以指定编码解析HTML内容 这里的四次字符编解码,有一次发生错误最终显示的就会是乱码。我们依次来分析各次的字符编码是如何设置的。 - 保存JSP文件,这是在编辑器中设置的,比如eclipse中,设置文件字符类型为utf-8。 - JSP文件开头的&%@ page language="java" contentType="text/ charset=utf-8" pageEncoding="utf-8"%&,其中pageEncoding用来告诉tomcat此文件所用的字符编码。这个编码应该与eclipse保存文件用的编码一致。Tomcat以此编码方式来读取JSP文件并编译。 - page标签中的contentType用来设置tomcat往浏览器发送HTML内容所使用的编码。这个编码会在HTTP响应头中指定以通知浏览器。 - 浏览器根据HTTP响应头中指定的字符编码来解析HTML内容。如:HTTP/1.1 200 OKDate: Mon, 01 Sep :31 GMTServer: Apache/2.2.4 (Win32) mod_jk/1.2.26Vary: Host,Accept-EncodingSet-Cookie: JAVA2000_STYLE_ID=1; Domain=www.java2000. Expires=Thu, 03-Nov-:10 GMT; Path=/Content-Encoding: gzipTransfer-Encoding: chunkedContent-Type: text/charset=UTF-8 另外,HTML中有个标签&meta http-equiv="Content-Type" content="text/ charset=UTF-8"&中也指定了charset。不过这个字符编码只有在当网页保存在本地作为静态网页时有效,因为没有HTTP头,所以浏览器根据此标签来识别HTML内容的编码方式。 现在在JSP文件中硬编码出现乱码的机会比较小了,因为大家都用了如eclipse的编辑器,基本上可以自动保证这几个编码设置的正确性。现在更多碰到的是在JSP文件中从其他数据源中读取中文字符所产生的乱码问题。 三、在JSP文件中读取字符文件并在页面中显示,中文字符显示为乱码。 比如,我们在JSP文件中使用以下代码: &% BufferedReader reader = new BufferedReader(new FileReader("D://test.txt")); String content = reader.readLine(); reader.close(); %& &%=content%& test.txt里保存的是中文字符,但在浏览器上看到的乱码。这是个经常见到的问题。我们继续用之前的方法一步步来分析输入和输出流 1. test.txt是以某种编码方式保存中文字符,比如UTF-8。 2. BufferedReader直接读取test.txt的字节内容并以默认方式构造字符串。分析BufferedReader的代码,我们可以看到BufferedReader调用了FileReader的read方法,而FileReader又调用了FileInputStream的native的read方法。所谓native的方法,就是操作系统底层方法。那么我们操作系统是中文系统,所以FileInputStream默认用GBK方式读取文件。因为我们保存test.txt用的是UTF-8,所以在这里读取文件内容使用GBK是错误的编码。 3. &%=content%&其实就是out.print(content),这里又用到了HTTP的输出流JspWriter,于是字符串content又被以JSP的page标签中指定的UTF-8方式编码成字节数组被发送到浏览器端。 4. 浏览器以HTTP头中指定的方式解码字符,这时无论是用GBK还是UTF-8解码,显示的都是乱码。 可见,我们字符编码转换在第二步时出错了,UTF-8的字符串被当做GBK读入了内存中。 解决这个乱码问题有两种方法,一是把test.txt用GBK保存,则FileInputStream能正确读入中文字符;二是使用InputStreamReader来转换字符编码,如: InputStreamReader sr = new InputStreamReader(new FileInputStream("D://test.txt"),"utf-8"); BufferedReader reader = new BufferedReader(sr); 这样,JAVA就会用utf-8的方式来从文件中读取字符数据。 另外,我们可以通过在java命令后带上Dfile.encoding参数来指定虚拟机读取文件使用的默认字符编码,例如java -Dfile.encoding=utf-8 Test,这样,我们在JAVA代码里用System.getProperty("file.encoding")取到的值为utf-8。 四、JSP读取request.getParameter里的中文参数后,在页面显示为乱码。 在JAVA的WEB应用中,对request对象里的parameters的中文处理一直是常见也最难搞的一只大怪兽。经常是刚搞定了这边,那边又出了乱码。而导致这种复杂性的,主要是此过程中字符编解码次数非常多,而且无论是浏览器还是WEB服务器特别是TOMCAT总是不能给我们一个比较满意的支持。 首先我们来分析用GET方式上传参数的乱码情况。 例如我们在浏览器地址栏输入以下URL:http://localhost:8080/test/test.jspparam=大家好 我们的JSP代码如此处理param这个参数: &% String text = request.getParameter("param"); %& &%=text%& 而就这么简单的两句代码,我们很有可能在页面上看到这样的乱码:′óòo 网上对处理request.getParamter中的乱码有很多文章和方法,也都是正确的,只是方法太多让人一直不明白到底是为什么。这里给大家分析一下到底是怎么一回事。 首先,我们来看看与request对象有哪些相关的编码设置: 1. JSP文件的字符编码 2. 请求这个带参数URL的源页面的字符编码 3. IE的高级设置中的选项“总以utf-8方式发送URL地址” 4. TOMCAT的server.xml中配置URIEncoding 5. 函数request.setCharacterEncoding() 6. JS的encodeURIComponent函数与JAVA的URLDecoder类 这么多条相关编码设置,也难怪大家被搞得头晕了。这里给大家根据各种情况给大家一一分析一下。见下表:
请求源页面编码
从地址栏输入URL访问
TOMCAT的URIEncoding设置
IE的UTF-8发送URL地址设置
显示符号乱码
显示符号乱码
显示符号乱码
显示符号乱码
地址栏输入
显示符号乱码
地址栏输入
显示符号乱码
显示汉字乱码
显示汉字乱码
地址栏输入
地址栏输入
IE6:奇数个的中文最后一位为乱码
IE6:奇数个的中文最后一位为乱码
地址栏输入
显示口字乱码
地址栏输入
显示口字乱码
显示问号乱码
显示问号乱码
地址栏输入
显示口字乱码
地址栏输入
显示口字乱码
以上表格里的现象,除了指名在IE7上,其他全是在IE6上测试的结果。 由这个表我们可以看到,IE的“总以utf-8方式发送URL地址”设置并不影响对parameter的解析,而从页面请求URL和从地址栏输入URL居然也有不同的表现。 根据这个表列出的现象,大家只要用smartSniff抓几个网络包,并稍稍调查一下TOMCAT的源代码,就可以得出以下结论: 1. IE设置中的“总以utf-8方式发送URL地址”只对URL的PATH部分起作用,对查询字符串是不起作用的。也就是说,如果勾选了这个选项,那么类似http://localhost:8080/test/大家好.jspparam=大家好这种URL,前一个“大家好”将被转化成utf-8形式,而后一个并没有变化。这里所说的utf-8形式,其实应该叫utf-8+escape形式,即%B4%F3%BC%D2%BA%C3这种形式。 那么,查询字符串中的中文字符,到底是用什么编码传送到服务器的呢?答案是系统默认编码,即GBK。也就是说,在我们中文操作系统上,传送给WEB服务器的查询字符串,总是以GBK来编码的。 2. 在页面中通过链接或location重定向或open新窗口的方式来请求一个URL,这个URL里面的中文字符是用什么编码的?答:是用该页面的编码类型。也就是说,如果我们从某个源JSP页面上的链接来访问http://localhost:8080/test/test.jspparam=大家好这个URL,如果源JSP页面的编码是UTF-8,则大家好这几个字的编码就是UTF-8。 而在地址栏上直接输入URL地址,或者从系统剪贴板粘贴到地址栏上,这个输入并非从页面中发起的,而是由操作系统发起的,所以这个编码只可能是系统的默认编码,与任何页面无关。我们还发现,在不同的浏览器上,用链接方式打开的页面,如果在地址栏上再敲个回车,显示的结果也会不同。IE上敲回车后显示不变化,而傲游上可能就会有乱码或乱码消失的变化。说明IE上敲回车,实际发送的是之前记忆下来的内存中的URL,而傲游上发送的从当前地址栏重新获取的URL。 3. TOMCAT的URIEncoding如果不加以设置,则默认使用ISO-8859-1来解码URL,设置后便用设置了的编码方式来解码。这个解码同时包括PATH部分和查询字符串部分。可见,这个参数是对用GET方式传递的中文参数最关键的设置。不过,这个参数只对GET方式传递的参数有效,对POST的无效。分析TOMCAT的源代码我们可以看到,在请求一个页面时,TOMCAT会尝试构造一个Request对象,在这个对象里,会从Server.xml里读取URIEncoding的值,并赋值给Parameters类的queryStringEncoding变量,而这个变量将在解析request.getParameter中的GET参数时用来指导字符解码。 4. request.setCharacterEncoding函数只对POST的参数有效,对GET的参数无效。且这个函数必须是在第一次调用request.getParameter之前使用。这是因为Parameters类有两个字符编码参数,一个是encoding,另一个是queryStringEncoding,而setCharacterEncoding设置的是encoding,这个是在解析POST的参数是才用到的。 所以,这就导致了我们通常都要分开处理POST和GET的字符编码,用TOMCAT自带的filter只能处理POST的,另外要设置URIEncoding来设置GET的。这样很麻烦而且URIEncoding无法根据内容来动态区分编码,总还是一个问题。 在调查TOMCAT的代码时发现了另一个在server.xml里的参数useBodyEncodingForURI,可以解决这个问题。这个参数设成true后,TOMCAT就会用request.setCharacterEncoding所设置的字符编码来同样解析GET参数了。这样,那个SetCharacterEncodingFilter就可以同时处理GET和POST参数了。 知道了以上知识后,我们再来分析一下前面表格中列出的几个典型现象。 第一条,请求源页面的编码为UTF-8,而TOMCAT的URIEncoding未指定,则TOMCAT用ISO8859-1方式来解码参数,所以从request中读出来后,内存中存储的为错误的UNICODE数据,导致之后到屏幕显示的所有转换全部出错。 第九条,请求源页面编码为GBK,而TOMCAT的URIEncoding也为GBK,TOMCAT用GBK方式去解码原本用GBK编码的字符,解码正确,内存中的UNICODE值正确,最终显示正确的中文。 第十三条,请求源页面编码为UTF-8,TOMCAT的URIEncoding也为UTF-8,而在IE6中最终显示的中文字符,如果是奇数个数,则最后一个会显示为乱码。这是为什么呢? 我的猜测是,这是因为IE6将URL地址发送时,对查询字符串是直接对UTF-8格式的字符使用GBK来编码,而不是对UNICODE的字符来用GBK编码,所以UTF-8的数据没有经过UNICODE而直接编码成了GBK。而到了TOMCAT这边,GBK的编码又被当成UTF-8做了解码。所以这个过程中经过了UTF-8转换成GBK,然后又从GBK转换成UTF-8的过程,而这种转换,恰好就会出现奇数个中文字符串的最后一位为乱码的现象。而在IE7中,估计把这种现象当做BUG已经被解决了,即在发送地址时会先转成UNICODE再编码成GBK。那么估计在IE7的浏览器+中文操作系统环境下,如果我们把TOMCAT的URIEncoding设置成GBK,无论JSP编码成什么格式,都不会出现乱码。这个没测试,请大家自己验证。 其他几条就不再做分析了,有兴趣的大家自己分析。 五、对URL做Encode和Decode 对于request参数的中文乱码问题,个人觉得最好的还是用URLEncode/URLDecode,因为如果你的WEB站点要支持国际化,最好就是保证从IE递送过来的参数永远是正确的UTF-8编码。 在IE端,我们可以用JS脚本来对参数编码:encodeURIComponent(),编码后中文字符便变成了%B4%F3%BC%D2%BA%C3这种形式。在JAVA端,可以用java.net.URLDecoder.decode来解码。不过这里要注意一个问题,就是TOMCAT会自动先对URL做一次decode,我们可以在TOMCAT的UDecoder类中看到这一点。不过TOMCAT并非使用了URLDecoder.decode,而是自己编写了一个decode函数。网上有些文章上介绍过一种处理乱码的方法便是在JS中对参数做两次encodeURIComponent,在JAVA中做一次decode,可以解决一些没有设置URIEncoding时发生的乱码问题。不过个人觉得如果弄懂了整个字符编码转换的过程,基本上是用不到这种方法的。 六、从数据库中读取中文字符数据,在页面上显示为乱码。 对于数据库中读取中文字符出现乱码的问题,本人遇到的还比较少,所以暂时没有总结。如果大家有类似的经验,欢迎补充说明,我一定注明作者身份。 好了,对各种字符乱码问题的分析就总结到这里,相信只要把握“以指定编码读取--转换为UNICODE--以指定编码输入”这基本步骤,初学者也可以很快分析出字符乱码的根源所在。另外我建议不要随便使用new String(str.getBytes(enc1),enc2)这种方式来强行转码,也不要随便使用网上的字符转码函数,我觉得只会把问题隐藏更深更复杂化。我们应该清晰地分析整个字符流的编解码过程,自然可以找出乱码的根源所在,从而保证整个字符流动中,在内存中的UNICODE始终是正确的。 另外再附上个人总结的乱码分析的一套秘籍!即从乱码的长相来分析是哪种编码转换错误。有人可以闻香识酒,我们也来个看字识码。请看下表:
辨瑕濂藉ソ瀛澶╁ぉ涓
大都为不认识的古文,并加杂日韩文
以GBK方式读取UTF-8编码的中文
大部分字符为小方块
以UTF-8的方式读取GBK编码的中文
±è|¥¥-|1¤¤
大部分字符为各种符号
以ISO8859-1方式读取UTF-8编码的中文
óéòaoo§°ììììòé
大部分字符为头顶带有各种类似声调符号的字母
以ISO8859-1方式读取GBK编码的中文
由月要好好学习天天向
字符串长度为偶数时正确,长度为奇数时最后的字符变为问号
以GBK方式读取UTF-8编码的中文,然后又用UTF-8的格式再次读取
锟斤拷锟斤拷要锟矫猴拷学习锟斤拷锟斤拷锟斤拷
全中文字符,且大部分字符为“锟斤拷”这几个字符
以UTF-8方式读取GBK编码的中文,然后又用GBK的格式再次读取
不过个人至今仍然弄不明白的就是问号码的产生原因,问号码即所有字符几乎全部为问号的乱码。问号码的出现有多种情况。我目前能确认的当我们把中文字符强行以ISO8859-1编码写入文件后,字符的高位信息会丢失,从而再次从文件中读出字符时便全部变为问号符。而我在JAVA代码中用UTF-8的方式去读取GBK编码的字符,出来的也是问号码,而并非口字码,这是我百思不得其解的问题。
网友评论仅供其表达个人看法,并不表明网易立场。&&&&&&& 这些天开发一个项目,服务器是tomcat,操作系统是xp,采用的是MVC架构,模式是采用Facade模式,总是出现乱码,通过简单的设置页面字符集,总算可以正确显示中文,可是没想到表单里提交的数据里的中文还是有乱码,我狂晕,没想到JSP里的乱码问题比ASP里严重多了,自己也解决了好多天,同事也帮忙解决,也参考了网上众多网友的文章和意见,总算是搞定。但是好记性不如烂笔杆,所以特意记下,以防止自己遗忘,同时也给那些遇到同样问题的人提供一个好的参考途径:
&&&&&&& 以下内容参考了网上的方法
(一)&&&&JSP设计页面上是中文,但运行时看到的是乱码:
解决的办法就是在JSP页面的编码的地方&%@&page&language="java"&contentType="text/charset=GBK"&%&,因为Jsp转成Java文件时的编码问题,默认的话有的服务器是ISO-8859-1,如果一个JSP中直接输入了中文,Jsp把它当作ISO8859-1来处理是肯定有问题的,这一点,我们可以通过查看Jasper所生成的Java中间文件来确认
(二)&&&&当用Request对象获取客户提交的汉字代码的时候,会出现乱码,比如表单里:
解决的办法是:要配置一个filter,也就是一个Servelet的过滤器,代码如下:
import&java.io.IOE
import&javax.servlet.F
import&javax.servlet.FilterC
import&javax.servlet.FilterC
import&javax.servlet.ServletE
import&javax.servlet.ServletR
import&javax.servlet.ServletR
import&javax.servlet.UnavailableE
public&class&SetCharacterEncodingFilter&implements&Filter&{
&&&&public&void&destroy()&
&&&&public&void&doFilter(ServletRequest&request,&ServletResponse&response,
&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&&& FilterChain&chain)throws&IOException,&ServletException&
&&&&request.setCharacterEncoding("GBK");
&&&&//&传递控制到下一个过滤器
&&&&chain.doFilter(request,&response);
&&&&public&void&init(FilterConfig&filterConfig)&throws&ServletException&
配置web.xml
&filter-name&Set&Character&Encoding&/filter-name&
&filter-class&com.SetCharacterEncodingFilter&/filter-class&
&filter-mapping&
&filter-name&Set&Character&Encoding&/filter-name&
&url-pattern&/*&/url-pattern&
&/filter-mapping&
如果你的还是出现这种情况的话你就往下看看是不是你出现了第四中情况,你的Form提交的数据是不是用get提交的,一般来说用post提交的话是没有问题的,如果是的话,你就看看第四中解决的办法。
还有就是对含有汉字字符的信息进行处理,处理的代码是:
package&dbJavaB
public&class&CodingConvert
public&CodingConvert()
&&&&&&&& //process
public&String&toGb(String&uniStr)
&&&&&String&gbStr&=&"";
&&&&&if(uniStr&==&null)
&&&&&&&&& &&&uniStr&=&"";
&&&byte[]&tempByte&=&uniStr.getBytes("ISO8859_1");
&&&gbStr&=&new&String(tempByte,"GB2312");
&&&&& catch(Exception&ex)
&&&&&&&&&&&&& // exception process
&&&&&return&gbS
&public&String&toUni(String&gbStr)
&&&&&String&uniStr&=&"";
&&&&&if(gbStr&==&null)
&&&&&&&&&&& gbStr&=&"";
&&&byte[]&tempByte&=&gbStr.getBytes("GB2312");
&&&uniStr&=&new&String(tempByte,"ISO8859_1");
&&&&&& catch(Exception&ex)
&&&&& return&uniS
你也可以在直接的转换,首先你将获取的字符串用ISO-8859-1进行编码,然后将这个编码存放到一个字节数组中,然后将这个数组转化成字符串对象就可以了,例如:
String&str=request.getParameter(“girl”);
Byte&B[]=str.getBytes(“ISO-21;);
Str=new&String(B);
通过上述转换的话,提交的任何信息都能正确的显示。
(三)&&&&在Formget请求在服务端用request.&getParameter(“name”)时返回的是乱码;按tomcat的做法设置Filter也没有用或者用request.setCharacterEncoding("GBK");也不管用问题是出在处理参数传递的方法上:如果在servlet中用doGet(HttpServletRequest&request,&HttpServletResponse&response)方法进行处理的话前面即使是写了:
request.setCharacterEncoding("GBK");
response.setContentType("text/charset=GBK");
也是不起作用的,返回的中文还是乱码!!!如果把这个函数改成doPost(HttpServletRequest&request,&HttpServletResponse&response)一切就OK了。
同样,在用两个JSP页面处理表单输入之所以能显示中文是因为用的是post方法传递的,改成get方法依旧不行。
由此可见在servlet中用doGet()方法或是在JSP中用get方法进行处理要注意。这毕竟涉及到要通过浏览器传递参数信息,很有可能引起常用字符集的冲突或是不匹配。
解决的办法是:
1)&打开tomcat的server.xml文件,找到区块,加入如下一行:&
URIEncoding=”GBK”&
完整的应如下:&
&Connector&port="8080"&maxThreads="150"&minSpareThreads="25"&maxSpareThreads="75"
&enableLookups="false"&redirectPort="8443"&acceptCount="100"&debug="0"
&connectionTimeout="20000"&disableUploadTimeout="true"&URIEncoding="GBK"/&
2)重启tomcat,一切OK。
需要加入的原因大家可以去研究&$TOMCAT_HOME/webapps/tomcat-docs/config/http.html下的这个文件就可以知道原因了。需要注意的是:这个地方如果你要是用UTF-8的时候在传递的过程中在Tomcat中也是要出现乱码的情况,如果不行的话就换别的字符集。
(四)&&&&JSP页面上有中文,按钮上面也有中文,但是通过服务器查看页面的时候出现乱码:
&&&&&解决的办法是:首先在JSP文件中不应该直接包含本地化的消息文本,而是应该通过&bean:message&标签从Resource&Bundle中获得文本。应该把你的中文文本放到Application.properties文件中,这个文件放在WEB-INF/classes/*下,例如我在页面里有姓名,年龄两个label,我首先就是要建一个Application.properties,里面的内容应该是name=”姓名”&age=”年龄”,然后我把这个文件放到WEB-INF/classes/properties/下,接下来根据Application.properties文件,对他进行编码转化,创建一个中文资源文件,假定名字是Application_cn.properties。在JDK中提供了native2ascii命令,他能够实现字符编码的转换。在DOS环境中找到你放置Application.properties的这个文件的目录,在DOS环境中执行一下命令,将生成按GBK编码的中文资源文件Application_cn.properties:native2ascii&?encoding&gbk&Application.properties&Application_cn.properties执行以上命令以后将生成如下内容的Application_cn.properties文件:name=\u59d3\u540d&age=\u5e74\u9f84,在Struts-config.xml中配置:&message-resources&parameter="properties.Application_cn"/&。到这一步,基本上完成了一大半,接着你就要在JSP页面上写&%@&page&language="java"&contentType="text/charset=GBK"&%&,到名字的那个label是要写&bean:message&key=”name”&,这样的化在页面上出现的时候就会出现中文的姓名,年龄这个也是一样,按钮上汉字的处理也是同样的。
(五)&&&&写入到数据库是乱码:
解决的方法:要配置一个filter,也就是一个Servelet的过滤器,代码如同第二种时候一样。
如果你是通过JDBC直接链接数据库的时候,配置的代码如下:jdbc:mysql://localhost:3306/workshopdb?useUnicode=true&characterEncoding=GBK,这样保证到数据库中的代码是不是乱码。
如果你是通过数据源链接的化你不能按照这样的写法了,首先你就要写在配置文件中,在tomcat&5.0.19中配置数据源的地方是在
C:\Tomcat&5.0\conf\Catalina\localhost这个下面,我建立的工程是workshop,放置的目录是webapp下面,workshop.xml的配置文件如下:
&!--&insert&this&Context&element&into&server.xml&--&
&Context&path="/workshop"&docBase="workshop"&debug="0"
&&&&&&&&&& reloadable="true"&&
&&&Resource&name="jdbc/WorkshopDB"
&&&&&&&&&&&&&&&auth="Container"
&&&&&&&&&&&&&&&type="javax.sql.DataSource"&/&
&&&ResourceParams&name="jdbc/WorkshopDB"&
&&&&&parameter&
&&&&&&&name&factory&/name&
&&&&&&&value&mons.dbcp.BasicDataSourceFactory&/value&
&&&&&/parameter&
&&&&&parameter&
&&&&&&&name&maxActive&/name&
&&&&&&&value&100&/value&
&&&&&/parameter&
&&&&&parameter&
&&&&&&&name&maxIdle&/name&
&&&&&&&value&30&/value&
&&&&&/parameter&
&&&&&parameter&
&&&&&&&name&maxWait&/name&
&&&&&&&value&10000&/value&
&&&&&/parameter&
&&&&&&&parameter&
&&&&&&name&username&/name&
&&&&&&value&root&/value&
&&&&&/parameter&
&&&&&parameter&
&&&&&&name&password&/name&
&&&&&&value&&/value&
&&&&&/parameter&
&&&&&!--&Class&name&for&mm.mysql&JDBC&driver&--&
&&&&&parameter&
&&&&&&&&name&driverClassName&/name&
&&&&&&&&value&com.mysql.jdbc.Driver&/value&
&&&& &/parameter&
&&& &parameter&
&&&&&&&name&url&/name&
&&&&&&& &value&
&&&&&&&&&& &![CDATA[jdbc:mysql://localhost:3306/workshopdb?useUnicode=true&characterEncoding=GBK]]&
&&&&&&& &/value&
&&&&&/parameter&
&&&/ResourceParams&
&/Context&
粗体的地方要特别的注意,和JDBC直接链接的时候是有区别的,如果你是配置正确的化,当你输入中文的时候到数据库中就是中文了,有一点要注意的是你在显示数据的页面也是要用&%@&page&language="java"&contentType="text/charset=GBK"&%&这行代码的。需要注意的是有的前台的人员在写代码的是后用Dreamver写的,写了一个Form的时候把他改成了一个jsp,这样有一个地方要注意了,那就是在Dreamver中Action的提交方式是request的,你需要把他该过来,因为在jsp的提交的过程中紧紧就是POST和GET两种方式,但是这两种方式提交的代码在编码方面还是有很大不同的,这个在后面的地方进行说明。3
以上就是我在开发系统中解决中文的问题,不知道能不能解决大家的问题,时间匆忙,没有及时完善,文笔也不是很好,有些地方估计是词不达意。大家可以给我意见,希望能共同进步。
其它上按以上的方法就可以解决的。
第(二)种方法里,这个过滤器比较简单,如果字符集不同的话,那就要手动修改这个过滤器,下面介绍一个功能强的过滤器:
package com.manage.
import javax.servlet.*;
import java.io.IOE
public class SetCharacterEncodingFilter implements Filter {
protected String encoding =
protected FilterConfig filterConfig =
protected boolean ignore =
public void destroy() {
this.encoding =
this.filterConfig =
public void doFilter(ServletRequest request, ServletResponse response,
FilterChain chain)
throws IOException, ServletException {
if (ignore || (request.getCharacterEncoding() == null)) {
String encoding = selectEncoding(request);
if (encoding != null)
request.setCharacterEncoding(encoding);
chain.doFilter(request, response);
public void init(FilterConfig filterConfig) throws ServletException {
this.filterConfig = filterC
this.encoding = filterConfig.getInitParameter("encoding");
String value = filterConfig.getInitParameter("ignore");
if (value == null)
this.ignore =
else if (value.equalsIgnoreCase("true"))
this.ignore =
else if (value.equalsIgnoreCase("yes"))
this.ignore =
this.ignore =
protected String selectEncoding(ServletRequest request) {
return (this.encoding);
/**在web.xml里这样设置
&&&filter&
&&&filter-name&Set Character Encoding&/filter-name&
&&&filter-class&
&&&com.manage.filter.SetCharacterEncodingFilter
&&&/filter-class&
&&&init-param&
&&&&param-name&encoding&/param-name&
&&&&param-value&UTF-8&/param-value&
&&&/init-param&
&&&init-param&
&&&&param-name&ignore&/param-name&
&&&&param-value&true&/param-value&
&&&/init-param&
&&/filter&
&&filter-mapping&
&&&filter-name&Set Character Encoding&/filter-name&
&&&servlet-name&action&/servlet-name&
&&/filter-mapping&
针对第(二)种方法,还有一个很简单的方法,就是在每个页面里都加上以下代码:&%request.setCharacterEncoding("gb2312");%&
&%response.setCharacterEncoding("gb2312");%&
这样听说行,不过我试了没有效果
&&&&&&& 针对MYSQL数据库的中文乱码问题,我已经总结了一篇专门的解决方法,
原创文章如转载,请注明:转载自: : /
本文链接地址:
如果你喜欢本文,请顶一下,支持我,你的支持是我继续发好文章的最大动力。谢谢。
好东西需要分享,快把本文发给你的朋友吧~!~
文章 - 614

我要回帖

更多关于 电脑总是蓝屏 的文章

 

随机推荐