Linux下MySQL,jsp的中文问题解决

我的环境为Ubuntu 6.10, MySQL 5.0.24a-Debian_9ubuntu1(直接apt-get而来), tomcat 5.5.20

这个也算是一个经典问题了,写在这里以后方便查阅

没什么原创,结合前人的经验,我的步骤如下


1、修改/etc/mysql/my.cnf,在

[mysqld]下添加一行

java 代码
  1. [mysqld]   
  2. default-character-set=utf8  

保存退出后,重新启动mysql的服务

java 代码
  1. sudo /etc/init.d/mysql restart  

2、将所有需要输入中文的jsp页面的pageEncoding都设为UTF-8,即在开始加上

java 代码
  1. <%@ page language="java" pageEncoding="UTF-8"%>  

3、从页面接受的中文字符串在加入数据库前都先进行转码,也很简单

java 代码
 
  1. public static String getDecodedString(String str)  
  2.   
  3. {  
  4.   
  5. try {  
  6.   
  7. return new String(str.getBytes("ISO8859-1"), "UTF-8");  
  8.   
  9. catch (UnsupportedEncodingException e) {  
  10.   
  11. e.printStackTrace();  
  12.   
  13. }  
  14.   
  15. return str;  
  16.   
  17. }  

这是因为Tomcat默认的编码格式是ISO8859-1,当然,也可以通过重新编译Tomcat的源码来将这个默认编码改为UTF-8,这是另一种办法,我没试过

补充:还有一种一了百了的方法就是用fliter,作用就是将所有页面输入的数据都改变编码格式,需要自己写一个转换类(和上面的差不多一样),同时在web.xml里配置下就可以了

4、数据库建立的时要将含中文字符的字段的charset设置为UTF-8,例如

sql 代码
 
  1. CREATE TABLE test (  
  2.   
  3. `nameVARCHAR(100) CHARACTER SET utf8 COLLATE utf8_unicode_ci NOT NULL DEFAULT ''  
  4.   

这样就可以使得mysql支持中文了


 

题外话:MySQL-Administrator有一个很恶心的bug,就是在进行User Administration的时候会整个界面死掉,控制台下报

cpp 代码
 
  1. ** (mysql-admin:20978): CRITICAL **: void MGFileBrowserList::get_row_object(const Gtk::TreeIter&, std::string&): assertion `iter' failed  

 

网上显示已经fixed release,但是很可惜的是至少在我的ubuntu上的仍然存在

你可能感兴趣的:(tomcat,mysql,jsp,linux,ubuntu)