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

http://syhan.javaeye.com/blog/59113

 

 

关键字:   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 代码
    • sudo /etc/init.d/mysql restart  

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

java 代码
  1. <%@ 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 (  
    •   
    • `nameVARCHAR(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上的仍然存在
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值