ImageVerifierCode 换一换
格式:DOCX , 页数:14 ,大小:22.30KB ,
资源ID:9677668      下载积分:1 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bingdoc.com/d-9677668.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(如何解决Java中的中文乱码问题.docx)为本站会员(b****8)主动上传,冰点文库仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰点文库(发送邮件至service@bingdoc.com或直接QQ联系客服),我们立即给予删除!

如何解决Java中的中文乱码问题.docx

1、如何解决Java中的中文乱码问题 如何解决Java中的中文乱码问题?一、中文问题的来源计算机最初的操作系统支持的编码是单字节的字符编码,于是,在计算机中一切处理程序最初都是以单字节编码的英文为准进行处理。随着计算机的发展,为了适应世界其它民族的语言(当然包括我们的汉字),人们提出了UNICODE编码,它采用双字节编码,兼容英文字符和其它民族的双字节字符编码,所以,目前,大多数国际性的软件内部均采用UNICODE编码,在软件运行时,它获得本地支持系统(多数时间是操作系统)默认支持的编码格式,然后再将软件内部的UNICODE转化为本地系统默认支持的格式显示出来。Java的JDK和JVM即是如此,我

2、这里说的JDK是指国际版的JDK,我们大多数程序员使用的是国际化的JDK版本,以下所有的JDK均指国际化的JDK版本。我们的汉字是双字节编码语言,为了能让计算机处理中文,我们自己制定的gb2312、GBK、GBK2K等标准以适应计算机处理的需求。所以,大部分的操作系统为了适应我们处理中文的需求,均定制有中文操作系统,它们采用的是GBK,GB2312编码格式以正确显示我们的汉字。如:中文Win2K默认采用的是GBK编码显示,在中文WIN2k中保存文件时默认采用的保存文件的编码格式也是GBK的,即,所有在中文WIN2K中保存的文件它的内部编码默认均采用GBK编码,注意:GBK是在GB2312基础上

3、扩充来的。由于Java语言内部采用UNICODE编码,所以在JAVA程序运行时,就存在着一个从UNICODE编码和对应的操作系统及浏览器支持的编码格式转换输入、输出的问题,这个转换过程有着一系列的步骤,如果其中任何一步出错,则显示出来的汉字就会出是乱码,这就是我们常见的JAVA中文问题。同时,Java是一个跨平台的编程语言,也即我们编写的程序不仅能在中文windows上运行,也能在中文Linux等系统上运行,同时也要求能在英文等系统上运行(我们经常看到有人把在中文win2k上编写的JAVA程序,移植到英文Linux上运行)。这种移植操作也会带来中文问题。还有,有人使用英文的操作系统和英文的IE

4、等浏览器,来运行带中文字符的程序和浏览中文网页,它们本身就不支持中文,也会带来中文问题。有,几乎所有的浏览器默认在传递参数时都是以UTF-8编码格式来传递,而不是按中文编码传递,所以,传递中文参数时也会有问题,从而带来乱码现象。总之,以上几个方面是JAVA中的中文问题的主要来源,我们把以上原因造成的程序不能正确运行而产生的问题称作:JAVA中文问题。2、JAVA编码转换的详细过程我们常见的JAVA程序包括以下类别:*直接在console上运行的类(包括可视化界面的类)*JSP代码类(注:JSP是Servlets类的变型)*Servelets类*EJB类*其它不可以直接运行的支持类这些类文件中,

5、都有可能含有中文字符串,并且我们常用前三类JAVA程序和用户直接交互,用于输出和输入字符,如:我们在JSP和Servlet中得到客户端送来的字符,这些字符也包括中文字符。无论这些JAVA类的作用如何,这些JAVA程序的生命周期都是这样的:*编程人员在一定的操作系统上选择一个合适的编辑软件来实现源程序代码并以.java扩展名保存在操作系统中,例如我们在中文win2k中用记事本编辑一个java源程序;*编程人员用JDK中的javac.exe来编译这些源代码,形成.class类(JSP文件是由容器调用JDK来编译的);*直接运行这些类或将这些类布署到WEB容器中去运行,并输出结果。那么,在这些过程中

6、,JDK和JVM是如何将这些文件如何编码和解码并运行的呢?这里,我们以中文win2k操作系统为例说明JAVA类是如何来编码和被解码的。第一步,我们在中文win2k中用编辑软件如记事本编写一个Java源程序文件(包括以上五类JAVA程序),程序文件在保存时默认采用了操作系统默认支持GBK编码格式(操作系统默认支持的格式为file.encoding格式)形成了一个.java文件,也即,java程序在被编译前,我们的JAVA源程序文件是采用操作系统默认支持的file.encoding编码格式保存的,java源程序中含有中文信息字符和英文程序代码;要查看系统的file.encoding参数,可以用以下

7、代码:public class ShowSystemDefaultEncoding public static void main(String args) String encoding = System.getProperty( file.encoding );System.out.println(encoding);第二步,我们用JDK的javac.exe文件编译我们的Java源程序,由于JDK是国际版的,在编译的时候,如果我们没有用-encoding参数指定我们的JAVA源程序的编码格式,则javac.exe首先获得我们操作系统默认采用的编码格式,也即在编译java程序时,若我们不指定

8、源程序文件的编码格式,JDK首先获得操作系统的file.encoding参数(它保存的就是操作系统默认的编码格式,如WIN2k,它的值为GBK),然后JDK就把我们的java源程序从file.encoding编码格式转化为JAVA内部默认的UNICODE格式放入内存中。然后,javac把转换后的unicode格式的文件进行编译成.class类文件,此时.class文件是UNICODE编码的,它暂放在内存中,紧接着,JDK将此以UNICODE编码的编译后的class文件保存到我们的操作系统中形成我们见到的.class文件。对我们来说,我们最终获得的.class文件是内容以UNICODE编码格式保

9、存的类文件,它内部包含我们源程序中的中文字符串,只不过此时它己经由file.encoding格式转化为UNICODE格式了。这一步中,对于JSP源程序文件是不同的,对于JSP,这个过程是这样的:即WEB容器调用JSP编译器,JSP编译器先查看JSP文件中是否设置有文件编码格式,如果JSP文件中没有设置JSP文件的编码格式,则JSP编译器调用JDK先把JSP文件用JVM默认的字符编码格式(也即WEB容器所在的操作系统的默认的file.encoding)转化为临时的Servlet类,然后再把它编译成UNICODE格式的class类,并保存在临时文件夹中。如:在中文win2k上,WEB容器就把JSP

10、文件从GBK编码格式转化为UNICODE格式,然后编译成临时保存的Servlet类,以响应用户的请求。第三步,运行第二步编译出来的类,分为三种情况:A、 直接在console上运行的类B、 EJB类和不可以直接运行的支持类(如JavaBean类)C、 JSP代码和Servlet类D、 JAVA程序和数据库之间下面我们分这四种情况来看。A、直接在console上运行的类这种情况,运行该类首先需要JVM支持,即操作系统中必须安装有JRE。运行过程是这样的:首先java启动JVM,此时JVM读出操作系统中保存的class文件并把内容读入内存中,此时内存中为UNICODE格式的class类,然后JVM

11、运行它,如果此时此类需要接收用户输入,则类会默认用file.encoding编码格式对用户输入的串进行编码并转化为unicode保存入内存(用户可以设置输入流的编码格式)。程序运行后,产生的字符串(UNICODE编码的)再回交给JVM,最后JRE把此字符串再转化为file.encoding格式(用户可以设置输出流的编码格式)传递给操作系统显示接口并输出到界面上。以上每一步的转化都需要正确的编码格式转化,才能最终不出现乱码现象。B、EJB类和不可以直接运行的支持类(如JavaBean类)由于EJB类和不可以直接运行的支持类,它们一般不与用户直接交互输入和输出,它们常常与其它的类进行交互输入和输出

12、,所以它们在第二步被编译后,就形成了内容是UNICODE编码的类保存在操作系统中了,以后只要它与其它的类之间的交互在参数传递过程中没有丢失,则它就会正确的运行。C、JSP代码和Servlet类经过第二步后,JSP文件也被转化为Servlets类文件,只不过它不像标准的Servlets一校存在于classes目录中,它存在于WEB容器的临时目录中,故这一步中我们也把它做为Servlets来看。对于Servlets,客户端请求它时,WEB容器调用它的JVM来运行Servlet,首先,JVM把Servlet的class类从系统中读出并装入内存中,内存中是以UNICODE编码的Servlet类的代码,

13、然后JVM在内存中运行该Servlet类,如果Servlet在运行的过程中,需要接受从客户端传来的字符如:表单输入的值和URL中传入的值,此时如果程序中没有设定接受参数时采用的编码格式,则WEB容器会默认采用ISO-8859-1编码格式来接受传入的值并在JVM中转化为UNICODE格式的保存在WEB容器的内存中。Servlet运行后生成输出,输出的字符串是UNICODE格式的,紧接着,容器将Servlet运行产生的UNICODE格式的串(如html语法,用户输出的串等)直接发送到客户端浏览器上并输出给用户,如果此时指定了发送时输出的编码格式,则按指定的编码格式输出到浏览器上,如果没有指定,则默

14、认按ISO-8859-1编码发送到客户的浏览器上。D、Java程序和数据库之间对于几乎所有数据库的JDBC驱动程序,默认的在JAVA程序和数据库之间传递数据都是以ISO-8859-1为默认编码格式的,所以,我们的程序在向数据库内存储包含中文的数据时,JDBC首先是把程序内部的UNICODE编码格式的数据转化为ISO-8859-1的格式,然后传递到数据库中,在数据库保存数据时,它默认即以ISO-8859-1保存,所以,这是为什么我们常常在数据库中读出的中文数据是乱码。3、分析常见的JAVA中文问题几个必须清楚的原则首先,经过上面的详细分析,我们可以清晰地看到,任何JAVA程序的生命期中,其编码转

15、换的关键过程是在于:最初编译成class文件的转码和最终向用户输出的转码过程。其次,我们必须了解JAVA在编译时支持的、常用的编码格式有以下几种:*ISO-8859-1,8-bit, 同8859_1,ISO-8859-1,ISO_8859_1等编码*Cp1252,美国英语编码,同ANSI标准编码*UTF-8,同unicode编码*GB2312,同gb2312-80,gb2312-1980等编码*GBK , 同MS936,它是gb2312的扩充及其它的编码,如韩文、日文、繁体中文等。同时,我们要注意这些编码间的兼容关体系如下:unicode和UTF-8编码是一一对应的关系。GB2312可以认为是

16、GBK的子集,即GBK编码是在gb2312上扩展来的。同时,GBK编码包含了20902个汉字,编码范围为:0 8140-0xfefe,所有的字符可以一一对应到UNICODE2.0中来。再次,对于放在操作系统中的.java源程序文件,在编译时,我们可以指定它内容的编码格式,具体来说用-encoding来指定。注意:如果源程序中含有中文字符,而你用-encoding指定为其它的编码字符,显然是要出错的。用-encoding指定源文件的编码方式为GBK或gb2312,无论我们在什么系统上编译含有中文字符的JAVA源程序都不会有问题,它都会正确地将中文转化为UNICODE存储在class文件中。然后,

17、我们必须清楚,几乎所有的WEB容器在其内部默认的字符编码格式都是以ISO-8859-1为默认值的,同时,几乎所有的浏览器在传递参数时都是默认以UTF-8的方式来传递参数的。所以,虽然我们的Java源文件在出入口的地方指定了正确的编码方式,但其在容器内部运行时还是以ISO-8859-1来处理的。4、中文问题的分类及其建议最优解决办法了解以上JAVA处理文件的原理之后,我们就可以提出了一套建议最优的解决汉字问题的办法。我们的目标是:我们在中文系统中编辑的含有中文字符串或进行中文处理的JAVA源程序经编译后可以移值到任何其它的操作系统中正确运行,或拿到其它操作系统中编译后能正确运行,能正确地传递中文

18、和英文参数,能正确地和数据库交流中英文字符串。我们的具体思路是:在JAVA程序转码的入口和出口及JAVA程序同用户有输入输出转换的地方限制编码方法使之正确即可。具体解决办法如下:1、 针对直接在console上运行的类对于这种情况,我们建议在程序编写时,如果需要从用户端接收用户的可能含有中文的输入或含有中文的输出,程序中应该采用字符流来处理输入和输出,具体来说,应用以下面向字符型节点流类型:对文件:FileReader,FileWrieter其字节型节点流类型为:FileInputStream,FileOutputStream对内存(数组):CharArrayReader,CharArrayW

19、riter其字节型节点流类型为:ByteArrayInputStream,ByteArrayOutputStream对内存(字符串):StringReader,StringWriter对管道:PipedReader,PipedWriter其字节型节点流类型为:PipedInputStream,PipedOutputStream同时,应该用以下面向字符型处理流来处理输入和输出:BufferedWriter,BufferedReader其字节型的处理流为:BufferedInputeStream,BufferedOutputStreamInputStreamReader,OutputStreamW

20、riter其字节型的处理流为:DataInputStream,DataOutputStream其中InputStreamReader和InputStreamWriter用于将字节流按照指定的字符编码集转换到字符流,如:InputStreamReader in = new InputStreamReader(System.in, GB2312 );OutputStreamWriter out = new OutputStreamWriter (System.out, GB2312 );例如:采用如下的示例JAVA编码就达到了要求:/Read.javaimport java.io.*;public

21、 class Read public static void main(String args) throws IOException String str = 中文测试,这是内部硬编码的串 + test english character String strin= BufferedReader stdin = new BufferedReader(new InputStreamReader(System.in, gb2312 ); /设置输入接口按中文编码BufferedWriter stdout = new BufferedWriter(new OutputStreamWriter(Sy

22、stem.out, gb2312 ); /设置输出接口按中文编码stdout.write( 请输入: );stdout.flush();strin = stdin.readLine();stdout.write( 这是从用户输入的串: +strin);stdout.write(str);stdout.flush();同时,在编译程序时,我们用以下方式来进行:javac -encoding gb2312 Read.java2、 针对EJB类和不可以直接运行的支持类(如JavaBean类)由于这种类它们本身被其它的类调用,不直接与用户交互,故对这种类来说,我们的建议的处理方式是内部程序中应该采用字

23、符流来处理程序内部的中文字符串(具体如上面一节中一样),同时,在编译类时用-encoding gb2312参数指示源文件是中文格式编码的即可。3、 针对Servlet类针对Servlet,我们建议用以下方法:在编译Servlet类的源程序时,用-encoding指定编码为GBK或GB2312,且在向用户输出时的编码部分用response对象的setContentType( text/html;charset=GBK );或gb2312来设置输出编码格式,同样在接收用户输入时,我们用request.setCharacterEncoding( GB2312 );这样无论我们的servlet类移植到

24、什么操作系统中,只有客户端的浏览器支持中文显示,就可以正确显示。如下是一个正确的示例:/HelloWorld.javapackage hello;import java.io.*;import javax.servlet.*;import javax.servlet.http.*;public class HelloWorld extends HttpServletpublic void init() throws ServletException public void doGet(HttpServletRequest request, HttpServletResponse respons

25、e) throws IOException, ServletExceptionrequest.setCharacterEncoding( GB2312 ); /设置输入编码格式response.setContentType( text/html;charset=GB2312 ); /设置输出编码格式PrintWriter out = response.getWriter(); /建议使用PrintWriter输出out.println( );out.println( Hello World! This is created by Servlet!测试中文! );out.println( );p

26、ublic void doPost(HttpServletRequest request, HttpServletResponse response) throws IOException, ServletExceptionrequest.setCharacterEncoding( GB2312 ); /设置输入编码格式response.setContentType( text/html;charset=GB2312 ); /设置输出编码格式String name = request.getParameter( name );String id = request.getParameter(

27、id );if(name=null) name= ;if(id=null) id= ;PrintWriter out = response.getWriter(); /建议使用PrintWriter输出out.println( );out.println( 你传入的中文字串是: + name);out.println( 你输入的id是: + id);out.println( );public void destroy() 请用javac -encoding gb2312 HelloWorld.java来编译此程序。测试此Servlet的程序如下所示:function Submit() /通过U

28、RL传递中文字符串值给Servletdocument.base.action = ./HelloWorld name=中文 document.base.method = POST document.base.submit();传给Servlet/testchinese.jspString action = request.getParameter( ACTION );String name = String str = if(action!=null action.equals( SENT )name = request.getParameter( name );str = request.g

29、etParameter( str );%function Submit()document.base.action = ACTION=SENT str=传入的中文 document.base.method = POST document.base.submit();提交if(action!=null action.equals( SENT )out.println( 你输入的字符为: +name);out.println( 你通过URL传入的字符为: +str);%由于大多数本地测试环境是TOMCAT,现也将其中文问题一并附上。Tomcat中文问题- -在tomcat5中发现了以前处理tomc

30、at4的方法不能适用于处理直接通过url提交的请求,上网找资料终于发现了最完美的解决办法,不用每个地方都转换了,而且无论get,和post都正常。写了个文档,贴出来希望跟我有同样问题的人不再像我一样痛苦一次:-)问题描述:1 表单提交的数据,用request.getParameter(“xxx”)返回的字符串为乱码或者?2 直接通过url如http:/localhost/a.jsp name=中国,这样的get请求在服务端用request. getParameter(“name”)时返回的是乱码;按tomcat4的做法设置Filter也没有用或者用request.setCharacterEnc

31、oding( GBK );也不管用原因:1 tomcat的j2ee实现对表单提交即post方式提示时处理参数采用缺省的iso-8859-1来处理2 tomcat对get方式提交的请求对query-string 处理时采用了和post方法不一样的处理方式。(与tomcat4不一样,所以设置setCharacterEncoding(“gbk”)不起作用。解决办法:首先所有的jsp文件都加上:1 实现一个Filter.设置处理字符集为GBK。(在tomcat的webapps/servlet-examples目录有一个完整的例子。请参考web.xml和SetCharacterEncodingFilter的配置。)1)只要把%TOMCAT安装目录%/ webappsservlets-examplesWEB-INFclassesfiltersSetCharacterEncodingFilter.class文件拷到你的webapp目录/filters下,如果没有filters目录,就创建一个。2)在你的web.xml里加入如下几行: Set Character Encodingfilters.SetCharacterEncodingFilterencodingGBKSet Character Encoding/*3)完成.2 ge

copyright@ 2008-2023 冰点文库 网站版权所有

经营许可证编号:鄂ICP备19020893号-2