分享

Mambo 中国社区 - Mambo使用交流 - ◆教你如何解决453h安装在mysql 4.1 以上的UTF8数据库中造成的乱码和安装失败问题◆ - powered by Discuz!

 ekylin 2006-02-25
◆教你如何解决453h安装在mysql 4.1 以上的UTF8数据库中造成的乱码和安装失败问题◆

这几天在尝试安装mambo 4.53h版, 由于我的数据库是mysq4.1以上版本,并且设定的字符集是UTF8 。在尝试安装了几次后发现以下几种情况:

1. 将数据库设置为 latin1 ,  不修改任何文件,在安装时无论选择gb2312 还是utf8,都可以完成安装,并且网页显示正常,但是通过phpmyadmin看数据表时发现,里面所有中文全部为乱码,也就是说,通过latin1字符集保存,可以正常显示中文网页,但是实际上在数据库中中文是乱码。 而且不能通过phpmyadmin备份(备份出来的文件,无论改成什么编码,里面中文均为乱码)。所以这不是王道,我没有做选择考虑。

2. 将数据库字符集设置成utf8, 不修改任何文件,在安装时无论选择gb2312还是utf8,都出现 1071  specified  key  too  long  max  length  1000  bytes  的错误。并且只要是数据库字符集设置成utf8,(utf8是一个 character set  作为 3 bytes存储,latin1 是作为1 bytes存储),无论是按照论坛中的一些意见,修改 installation/sql/mambo.sql 还是别的文件, 都会出现key 超过1000bytes的错误,安装不能继续。

我本意是要安装manbo的中文utf8版本,以方便和别的程序整合。所以在查询了google,论坛和其他一些资料后,经过尝试,终于以我的想法,以选择 manbo的utf8 字符集 在mysql4.1以上,并且字符集也是utf8 的数据库中安装成功。 网页显示中文正常,无乱码,并且用phpmyadmin查询数据库表时,所有中文也都显示正常,并且以utf8保存。以下是我的解决方法,仅供参考:


  • 首先设置数据库字符集为utf8,

    ALTER DATABASE  DEFAULT CHARACTER SET utf8 COLLATE utf8_general_ci
    或者通过phpmyadmin里面直接改也一样。

  • 修改 installation/sql/mambo.sql 文件:

    查找将所有的

    TYPE=MyISAM;
    替换成

    TYPE=MyISAM DEFAULT CHARSET=utf8 COLLATE=utf8_general_ci;
    查找

    UNIQUE KEY `section_value_value_aro` (`section_value`,`value`)


    UNIQUE KEY `#__gacl_section_value_value_aro` (`section_value`,`value`),
    并将这2行代码用 # 注释掉,或者删除,whatever~~


    在这一段代码下面,也就是

    # Table structure for table `#__core_acl_aro_groups`
    上面,按顺序增加以下4行代码:

    ALTER TABLE `#__core_acl_aro` CHANGE `section_value` `section_value` VARCHAR( 240 ) CHARACTER SET latin1 COLLATE latin1_bin NOT NULL default ‘0‘;


    ALTER TABLE `#__core_acl_aro` CHANGE `value` `value` VARCHAR( 240 ) CHARACTER SET latin1 COLLATE latin1_bin NOT NULL default ‘‘;


    ALTER TABLE `#__core_acl_aro` ADD UNIQUE `section_value_value_aro` ( `section_value` , `value` );


    ALTER TABLE `#__core_acl_aro` ADD UNIQUE `#__gacl_section_value_value_aro` (`section_value`,`value`);
    -----------------------------

    • 修改 includes/database.php 文件:
      查找

      $this->_table_prefix = $table_prefix;
      在该行代码下面添加以下三行代码:

      mysql_query("SET NAMES ‘utf8‘", $this->_resource);


      mysql_query("SET CHARACTER SET utf8", $this->_resource);


      mysql_query("SET COLLATION_CONNECTION=‘utf8_general_ci‘", $this->_resource);
      修改后保存。

    • 安装的时候,选择UTF8作为编码格式安装。


      如此修改后能够正常安装,并且在数据库中的中文显示和保存都正常,如果需要整合discuz或者其他程序的时候,也能够选择UTF8版本,并且整合后不会出现在注册时使用中文用户名,但是注册后显示为乱码的现象。

      注意事项
      经本方法修改后,请在升级manbo的时候,对 includes/database.php 做相应的修改,否则会出错。

      上面的解决方案,其实就是做了个妥协,将会超过1000bytes,并且不会影响中文存储和显示的数据表 mos_core_acl_aro 表中的 section_value字段和 value 字段以 latin1 处理,其他以utf8处理而已。这样就能做到顺利安装,而且mysql不会影响中文的显示和存储。
      我的服务器环境是:apache_2.0.55-win32
                                          php4.3.10
                                          mysql5.0.15
                                          ZendOptimizer-2.6.0-Windows
                                          MamboV4[1].5.3h_Global
      操作系统:winxp sp2

      完全按照搂主的方式进行更改,安装过程一切顺利,但是当我在管理平台进行如下操作的时候出现如下错误提示:
      操作:[内容]-〉[所有内容条目]
      错误:DB function failed with error number 1054
      Unknown column ‘c.access‘ in ‘on clause‘ SQL=SELECT c.*, g.name AS groupname, cc.name, u.name AS editor, f.content_id AS frontpage, s.title AS section_name, v.name AS author FROM mos_content AS c, mos_categories AS cc, mos_sections AS s LEFT JOIN mos_groups AS g ON g.id = c.access LEFT JOIN mos_users AS u ON u.id = c.checked_out LEFT JOIN mos_users AS v ON v.id = c.created_by LEFT JOIN mos_content_frontpage AS f ON f.content_id = c.id WHERE c.state >= 0 AND c.catid=cc.id AND cc.section=s.id AND s.scope=‘content‘ ORDER BY s.title, c.catid, cc.ordering, cc.title, c.ordering LIMIT 0,10

      不知道搂主或其他人有没有遇到过这种情况?
      解决方法:

      在这个文件中

      administrator\components\com_content\admin.content .php

      找到

      . "\n FROM #__content AS c, #__categories AS cc, #__sections AS s"

      替换为

      . "\n FROM #__categories AS cc, #__sections AS s, #__content AS c"

      共有2处要替换

        本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
        转藏 分享 献花(0

        0条评论

        发表

        请遵守用户 评论公约

        类似文章 更多