青青子衿, 悠悠我心, 但为君故, 沉吟至今
« 伤心藏南Google的中文名字—谷歌 »

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



  除非注明,月光博客文章均为原创,转载请以链接形式标明本文地址

  本文地址:http://www.williamlong.info/archives/469.html
  • 文章排行:
  • 1.IceKing
  • 谢谢你的提示,帮了我大忙了.
  • 2006/8/3 17:32:59   支持(11)反对(5) 回复
  • 2.newhand
  • 谢谢了。!我只是把contentType="text/html; charset=GB2312"添加到<[email protected]%>的属性里就能在浏览器里显示中文了。不过在eclipse里的preview窗口里却还是?号,不能显示中文。请指教。备注:我按你说的修改server.xml文件还是这样。
  • 2007/12/15 15:20:06   支持(11)反对(5) 回复
  • 3.偏激
  • 读书不认真,jsp开发教程里都有啊。
    text/html; charset=gb2312
    或者
    text/html; charset=UTF8
  • 2006/5/26 12:15:47   支持(11)反对(7) 回复
  • 4.newhand
  • 谢谢了。!我只是把contentType="text/html; charset=GB2312"添加到<[email protected]%>的属性里就能在浏览器里显示中文了。不过在eclipse里的preview窗口里却还是?号,不能显示中文。请指教。备注:我按你说的修改server.xml文件还是这样。
  • 2007/12/15 15:19:50   支持(11)反对(7) 回复
  • 5.test
  • 你写的还不够深入,只是表面现象
  • 2008/8/12 11:08:54   支持(8)反对(5) 回复
  • 6.孤独者
  • 不错!对tomcat又了解了一!
  • 2006/11/16 9:56:35   支持(7)反对(5) 回复
  • 8.草鞋
  • 一直都有关注你的日志.
  • 2006/4/13 11:32:53   支持(12)反对(12) 回复
  • 10.jc
  • 在action中,我用密文解析出来的明文,直接运行单个java文件测试的时候是正确滴,但是放到tomcat中,密文解析出来的中文就是乱码了,但是英文正常,这是什么原因啊
  • 2013/7/6 23:50:48   支持(6)反对(6) 回复
  • 11.晚会再回家
  • 太表面,一般解决不了问题
  • 2016/6/2 17:40:56   支持(0)反对(0) 回复
  • 12.sp
  • 表示要改成UTF-8才正常, 不知道为神马
    地点 于 2012-6-19 16:13:07 回复
    request.setCharacterEncoding("utf-8");
    response.setCharacterEncoding("utf-8");可以。
    response.setContentType("text/html; charset=GBK");不行
  • 2011/10/1 22:22:01   支持(9)反对(10) 回复
  • 14.lxxxxl
  • 谢谢,您的方法很有用,基本解决了J2EE开发中的中文乱码的问题.
  • 2010/9/3 14:58:42   支持(9)反对(11) 回复
  • 17.一杯矿泉水
  • main方法执行log4j时候控制台打印是中文file.encoding为UTF-8,但是tomcat启动时候控制台打印乱码,file.encoding为GBK,什么原因?项目在myeclipse下编码为UTF-8,log4j控制台输出编码为UTF-8,为什么项目编码会发生变化?
  • 2013/1/22 11:04:17   支持(10)反对(22) 回复

发表评论:

 请勿发送垃圾信息、广告、推广信息或链接,这样的信息将会被直接删除。

订阅博客

  • 订阅我的博客:订阅我的博客
  • 关注新浪微博:关注新浪微博
  • 关注腾讯微博:关注腾讯微博
  • 关注认证空间:关注QQ空间
  • 通过电子邮件订阅
  • 通过QQ邮件订阅

站内搜索

热文排行


月度排行

本站采用创作共用版权协议, 要求署名、非商业用途和相同方式共享. 转载本站内容必须也遵循“署名-非商业用途-相同方式共享”的创作共用协议.
This site is licensed under a Creative Commons Attribution-NonCommercial-ShareAlike 3.0 License.