我的环境为Ubuntu 6.10, MySQL 5.0.24a-Debian_9ubuntu1(直接apt-get而来), tomcat 5.5.20
这个也算是一个经典问题了,写在这里以后方便查阅
没什么原创,结合前人的经验,我的步骤如下
1、修改/etc/mysql/my.cnf,在
[mysqld]下添加一行
- [mysqld]
- default-character-set=utf8
保存退出后,重新启动mysql的服务
2、将所有需要输入中文的jsp页面的pageEncoding都设为UTF-8,即在开始加上
- <%@ page language="java" pageEncoding="UTF-8"%>
3、从页面接受的中文字符串在加入数据库前都先进行转码,也很简单
这是因为Tomcat默认的编码格式是ISO8859-1,当然,也可以通过重新编译Tomcat的源码来将这个默认编码改为UTF-8,这是另一种办法,我没试过
补充:还有一种一了百了的方法就是用fliter,作用就是将所有页面输入的数据都改变编码格式,需要自己写一个转换类(和上面的差不多一样),同时在web.xml里配置下就可以了
4、数据库建立的时要将含中文字符的字段的charset设置为UTF-8,例如
这样就可以使得mysql支持中文了
题外话:MySQL-Administrator有一个很恶心的bug,就是在进行User Administration的时候会整个界面死掉,控制台下报
网上显示已经fixed release,但是很可惜的是至少在我的ubuntu上的仍然存在
本文介绍如何在Ubuntu 6.10环境下配置MySQL 5.0.24a支持UTF-8编码,包括修改配置文件、调整Tomcat编码、使用过滤器统一编码及创建表时指定字符集。

被折叠的 条评论
为什么被折叠?



