• 技术文章 >后端开发 >php教程

    解决phpmyadmin 乱码,支持gb2312和utf-8_php技巧

    2016-05-17 09:43:55原创525
    解决phpmyadmin 乱码,支持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可能会有所不同.多试试几种方式.会有不一样的收获.

    转载请标明出处为www.phpv.net

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    上一篇:用PHP实现将GB编码转换为UTF8_php基础 下一篇:目录,文件操作详谈—PHP_php基础
    PHP编程就业班

    相关文章推荐

    • ajax+php 无刷新有关问题。 求大牛 • linux云主机,smarty程序,如若设置404页面? • 小弟我用ThinkPHP时的session有关问题 • PHP中装务器变量 $_SERVER 详解 • zend开发工具解决思路

    全部评论我要评论

  • 取消发布评论发送
  • 1/1

    PHP中文网