我的环境为Ubuntu 6.10, MySQL 5.0.24a-Debian_9ubuntu1(直接apt-get而来), tomcat 5.5.20
这个也算是一个经典问题了,写在这里以后方便查阅
没什么原创,结合前人的经验,我的步骤如下
1、修改/etc/mysql/my.cnf,在
[mysqld]下添加一行
java 代码
- [mysqld]
- default-character-set=utf8
保存退出后,重新启动mysql的服务
java 代码
sudo /etc/init.d/mysql restart
2、将所有需要输入中文的jsp页面的pageEncoding都设为UTF-8,即在开始加上
java 代码
- <%@ page language="java" pageEncoding="UTF-8"%>
3、从页面接受的中文字符串在加入数据库前都先进行转码,也很简单
java 代码
public static String getDecodedString(String str) { try { return new String(str.getBytes("ISO8859-1"), "UTF-8"); } catch (UnsupportedEncodingException e) { e.printStackTrace(); } return str; }
这是因为Tomcat默认的编码格式是ISO8859-1,当然,也可以通过重新编译Tomcat的源码来将这个默认编码改为UTF-8,这是另一种办法,我没试过
补充:还有一种一了百了的方法就是用fliter,作用就是将所有页面输入的数据都改变编码格式,需要自己写一个转换类(和上面的差不多一样),同时在web.xml里配置下就可以了
4、数据库建立的时要将含中文字符的字段的charset设置为UTF-8,例如
sql 代码
CREATE TABLE test ( `name` VARCHAR(100) CHARACTER SET utf8 COLLATE utf8_unicode_ci NOT NULL DEFAULT '' )
这样就可以使得mysql支持中文了
题外话:MySQL-Administrator有一个很恶心的bug,就是在进行User Administration的时候会整个界面死掉,控制台下报
cpp 代码
void MGFileBrowserList::get_row_object(const Gtk::TreeIter&, std::string&): assertion `iter' failed
** (mysql-admin:20978): CRITICAL **: 网上显示已经fixed release,但是很可惜的是至少在我的ubuntu上的仍然存在