解决phpmyadmin 在mysql5上的乱码,支持gb2312和utf-8

群里很多PHP爱好者一直受phpmyadmin的乱码问题困扰.我自从有了mysql-front后,我就很少使用phpmyadmin了.但每次连接远程主机,就比较慢.造成操作不便.今天有点时间,就下了最新的版本来研究.
首先说明我的数据库使用情况:
phpmyadmin 版本2.7.0-pl1
(如果你使用其它版本,可能会有所不同,请对照修改或者到 这里下载 phpmyadmin 2.7.0-pl1)
mysql版本MySQL 5.0.11-beta-nt
我在以前是使用GB2312编码方式,直接写入数据库的,字符集是mysql默认的latin1
PHP5以后我写的程序都改用UTF-8编码方式了,也是直接读写的.所以字符集也应试是mysql默认的latin1
我在用PHP操作数据时 没有 使用过以下语句:
SET character_set_client = utf8;
SET character_set_results = utf8;
SET character_set_connection = utf8;
好,开始吧.
把下载的ZIP包解压到www目录后打开文件夹...好久不见,配置文件名都从config.inc.php改成了config.default.php .
我修改了以下代码:
31行
$cfg['PmaAbsoluteUri'] = 'http://localhost/phpMyAdmin-2.7.0-pl1/';
45行
$cfg['blowfish_secret'] = 'this';
71行
$cfg['Servers'][$i]['auth_type'] = 'cookie'; // Authentication method (config, http or cookie based)?
接着,浏览器打开http://localhost/phpMyAdmin-2.7.0-pl1/ 使用root登录.language是默认的chinese simplified(zh-utf-8)
浏览一个UTF-8的表.乱码.
查看了html源代码,charset=utf-8
查看他的语言选择文件libraries/select_lang.lib.php
263行 'utf-8' => 'utf8',
我用的是默认的latin1 所以,这里应试改成latin1.改好保存,刷新.成功
转到一个以前用GB2312编码录入的库.是乱码.
退出.以chinese simplified(zh-gb2312)登录.到处看.乱码.
和上面一样找到libraries/select_lang.lib.php
250行 'gb2312' => 'gb2312',
把gb2312改为latin1.保存,刷新.却不行.还是一样.
很纳闷.查看了html源代码,charset还是utf-8.不对呀,应试是GB2312才正常.
无意中在首页的language下拉菜单中,发现没有登录时的chinese simplified(zh-gb2312)这一栏.(下图)
不解,仔细一对,列表项都是utf-8结束的.问题应试在这.
找libraries/select_lang.lib.php里对应的zh-gb2312,在它后面加上一个"-utf-8"
这回有了.查看了html源代码,charset是GB2312了.
如何在两种语言转换呢?
我试着回到UTF-8编码的表.没错,是乱码.
转到首页.language下拉菜单中选择zh-utf-8.再看看,OK了.
试着修改,添加新数据.都没再有乱码了.
结束:我的思路是以html的charset对照mysql的charset.
最后提醒:
如果你操作表时使用过以下语句:
SET character_set_client = utf8;
SET character_set_results = utf8;
SET character_set_connection = utf8;
那么你修改时libraries/select_lang.lib.php可能会有所不同.多试试几种方式.会有不一样的收获.
还有一个更好的变法就是在连接之后加入:mysql_query("SET NAMES 'GB2312'");
其中GB2312是你要输入或输出的字符集.这样子就不会乱码。而且不用改什么代码;
注意:数据库如果是PHPMYADMIN建的,要改成相应的字符集校对。
方法:点击数据库-->点击你所要修改的数据库链接-->选择操作链接-->进入操作界面后在整理的选项选择你所要的字符集,执行即可。
网页如下:
$conn = mysql_connect($host,$user,$pass);
mysql_query("SET NAMES 'GB2312'"); //加入这句,还没有加入前是乱码状态
mysql_select_db($database,$conn);
。。。
这样子就在改很少的代码的情况下实现无乱码的插入、或读出。
当然在PHPMYADMIN下也不会乱码。
我用:win2k+PHP5.10+mysql-noinstall-5.1.3-alpha-win32+phpMyAdmin 2.7.0-pl1的环境下测试成功
 
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值