Tomcat中文乱码问题的原理和解决方法

Tomcat中文乱码问题的原理和解决方法

研发

  自从接触Java和JSP以来,就不断与Java的中文乱码问题打交道,如今终于获得了完全的解决,现将咱们的解决心得与你们共享。 html

  1、Java中文问题的由来 数据库

  Java的内核和class文件是基于unicode的,这使Java程序具备良好的跨平台性,但也带来了一些中文乱码问题的麻烦。缘由主要有两方面,Java和JSP文件自己编译时产生的乱码问题和Java程序于其余媒介交互产生的乱码问题。 浏览器

  首先Java(包括JSP)源文件中极可能包含有中文,而Java和JSP源文件的保存方式是基于字节流的,若是Java和JSP编译成class文件过程当中,使用的编码方式与源文件的编码不一致,就会出现乱码。基于这种乱码,建议在Java文件中尽可能不要写中文(注释部分不参与编译,写中文不要紧),若是必须写的话,尽可能手动带参数-ecoding GBK或-ecoding gb2312编译;对于JSP,在文件头加上<%@ page contentType="text/html;charset=GBK"%>或<%@ page contentType="text/html;charset=gb2312"%>基本上就能解决这类乱码问题。 编码

  本文要重点讨论的是第二类乱码,即Java程序与其余存储媒介交互时产生的乱码。不少存储媒介,如数据库,文件,流等的存储方式都是基于字节流的,Java程序与这些媒介交互时就会发生字符(char)与字节(byte)之间的转换,例如从页面提交表单中提交的数据在Java程序里显示乱码等状况。 code

  若是在以上转换过程当中使用的编码方式与字节原有的编码不一致,极可能就会出现乱码。 server

  2、解决方法 xml

  对于流行的Tomcat来讲,有如下两种解决方法: htm

  1) 更改 D:\Tomcat\conf\server.xml,指定浏览器的编码格式为“简体中文”: unicode

  方法是找到 server.xml 中的 get

    <Connector port="8080" maxThreads="150" minSpareThreads="25" maxSpareThreads="75"
    enableLookups="false" redirectPort="8443" acceptCount="100"
    connectionTimeout="20000" disableUploadTimeout="true" URIEncoding='GBK' />

  标记,粗体字是我添加的。

  能够这样验证你的更改是否成功:在更改前,在你出现乱码的页面的IE浏览器,点击菜单“查看|编码”,会发现“西欧(ISO)”处于选中状态。而更改后,点击菜单“查看|编码”,会发现“简体中文(GB2312)”处于选中状态。

  b)更该 Java 程序,个人程序是这样的:

public class ThreeParams extends HttpServlet {
  public void doGet(HttpServletRequest request, HttpServletResponse response)
   throws ServletException, IOException {
      response.setContentType("text/html; charset=GBK");
      ...
  } 
}

  粗体字是必须要有的,它的做用是让浏览器把Unicode字符转换为GBK字符。这样页面的内容和浏览器的显示模式都设成了GBK,就不会乱码了。

相关文章
相关标签/搜索