月光博客 » 编程开发 » Tomcat中文乱码问题的原理和解决方法

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

  自从接触Java和JSP以来,就不断与Java的中文乱码问题打交道,现在终于得到了彻底的解决,现将我们的解决心得与大家共享。

  一、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程序里显示乱码等情况。

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

  二、解决方法

  对于流行的Tomcat来说,有以下两种解决方法:

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

  方法是找到 server.xml 中的

    <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,就不会乱码了。

顶一下 ▲()   踩一下 ▼()

相关文章

  1. 1
    jc   说道:
    在action中,我用密文解析出来的明文,直接运行单个java文件测试的时候是正确滴,但是放到tomcat中,密文解析出来的中文就是乱码了,但是英文正常,这是什么原因啊
    支持(13反对(7回复
  1. 2
    newhand   说道:
    谢谢了。!我只是把contentType="text/html; charset=GB2312"添加到<%@page%>的属性里就能在浏览器里显示中文了。不过在eclipse里的preview窗口里却还是?号,不能显示中文。请指教。备注:我按你说的修改server.xml文件还是这样。
    支持(14反对(9回复
  1. 3
    test   说道:
    你写的还不够深入,只是表面现象
    支持(10反对(6回复
  1. 4
    IceKing   说道:
    谢谢你的提示,帮了我大忙了.
    支持(11反对(8回复
  1. 5
    newhand   说道:
    谢谢了。!我只是把contentType="text/html; charset=GB2312"添加到<%@page%>的属性里就能在浏览器里显示中文了。不过在eclipse里的preview窗口里却还是?号,不能显示中文。请指教。备注:我按你说的修改server.xml文件还是这样。
    支持(11反对(8回复
  1. 6
    bessie   说道:
    不凑效阿!!
    支持(9反对(7回复
  1. 7
    偏激   说道:
    读书不认真,jsp开发教程里都有啊。
    text/html; charset=gb2312
    或者
    text/html; charset=UTF8
    支持(11反对(10回复
  1. 8
    sp   说道:
    表示要改成UTF-8才正常, 不知道为神马
    地点 于 2012-6-19 16:13:07 回复
    request.setCharacterEncoding("utf-8");
    response.setCharacterEncoding("utf-8");可以。
    response.setContentType("text/html; charset=GBK");不行
    支持(13反对(12回复
  1. 9
    宋垚   说道:
    不管用,一点都没有用
    支持(1反对(1回复
  1. 10
    草鞋   说道:
    一直都有关注你的日志.
    支持(12反对(13回复
  1. 11
    孤独者   说道:
    不错!对tomcat又了解了一!
    支持(7反对(8回复
  1. 12
      说道:
    两种方法都不奏效
    支持(9反对(10回复
  1. 13
    晚会再回家   说道:
    太表面,一般解决不了问题
    支持(0反对(1回复
  1. 14
    123   说道:
    误人子弟!!!!
    支持(0反对(2回复
  1. 15
    诗云鹏   说道:
    东北人,谢谢阿!
    支持(8反对(11回复
  1. 16
    wzhengpn   说道:
    谢谢你的分享!
    支持(3反对(8回复
  1. 17
    lxxxxl   说道:
    谢谢,您的方法很有用,基本解决了J2EE开发中的中文乱码的问题.
    支持(9反对(15回复
  1. 18
    abin   说道:
    好啊!感谢分享知识.
    支持(7反对(16回复
  1. 19
    一杯矿泉水   说道:
    main方法执行log4j时候控制台打印是中文file.encoding为UTF-8,但是tomcat启动时候控制台打印乱码,file.encoding为GBK,什么原因?项目在myeclipse下编码为UTF-8,log4j控制台输出编码为UTF-8,为什么项目编码会发生变化?
    支持(14反对(24回复

发表留言