2007-03-11
Linux下MySQL,jsp的中文问题解决
关键字: mysql 中文乱码 jsp我的环境为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 代码
- ** (mysql-admin:20978): CRITICAL **: void MGFileBrowserList::get_row_object(const Gtk::TreeIter&, std::string&): assertion `iter' failed
网上显示已经fixed release,但是很可惜的是至少在我的ubuntu上的仍然存在
发表评论
- 浏览: 14970 次
- 性别:

- 来自: Southeast University

- 详细资料
搜索本博客
我的相册
春游周庄
共 1 张
共 1 张
最近加入圈子
最新评论
-
破解了下ViPlugin
我想要,发一下吧,yanzixiangnande@gmail.com
-- by yanzixiang -
儿童节礼物
加油
-- by ouspec -
儿童节礼物
google过来的。 兄弟面得怎么样? 加我QQ吧,同行。6696136
-- by fiolvivi






评论排行榜