Typecho 评论 Emoji 表情报错 Database Query Error 解决方案!

宁采陈 2019-08-21 PM 4413℃ 27条

Typecho 默认不支持 Emoji 表情,这不是程序的锅,而是由于编码的问题造成,Emoji 是一种在 Unicode 位于u1F601-u1F64F区段的字符。这显然超出了目前常用的 UTF-8 字符集的编码范围u0000-uFFFF。在 MySQL 中,UTF-8 只支持最多 3 个字节,而 Emoji 是 4 个字节。所以评论中带有 Emoji 表情才会报错。

我们只需简单两步即可让 typecho 支持 emoji 表情评论,只要将默认的数据库编码 utf8 修改为 utf8mb4 即可。

1.修改评论内容字段的编码

使用数据库管理工具,找到 typecho_comments 评论表的 text 字段,将该字段的编码改为 utf8mb4_general_ci。

2.修改数据库配置文件

打开网站根目录数据库配置文件 config.inc.php
将 charset 的值由 utf8 改为 utf8mb4。

/** 定义数据库参数 */
$db = new Typecho_Db('Pdo_Mysql', 'echo_');
$db->addServer(array (
  'host' => 'localhost',
  'user' => 'echo',
  'password' => 'password',
  'charset' => 'utf8mb4', //修改这一参数
  'port' => '3306',
  'database' => 'echo',
), Typecho_Db::READ | Typecho_Db::WRITE);
Typecho_Db::set($db);

修改好后保存即可。

完工!

😀😁🤣😂😄😅😆😇😉😊🙂🙃☺️😋😌😍😘😙😜😝🤑🤓😎🤗🤡🤠😏😶😑😒🙄🤔😳😞😟😠😡😔😕☹️😣😖😫😤😮😱😨😯😦😢😥😪😓🤤😭😲🤥🤢🤧🤐😷🤒🤕😴💤

可以在我博客留言测试一下哦!

标签: typecho

非特殊说明,本博所有文章均为博主原创。

评论啦~



已有 27 条评论


  1. zhanzgx
    zhanzgx

    厉害哈哈

    回复 2020-09-29 11:24
  2. keepup
    keepup

    博主有没有遇到在手机上评论出现 Database Query Error ,在电脑端是没问题的

    回复 2020-09-08 11:30
    1. keepup
      keepup

      只有文字也会报错

      回复 2020-09-08 11:33
  3. 苏里
    苏里

    😎

    回复 2020-06-30 10:40
  4. DoubleF
    DoubleF

    不错``

    回复 2020-04-17 14:12
  5. jarome
    jarome

    大佬,我是postgresql的数据库,切换主题就报了一个 Database Query Error 。这个应该怎么弄啊?如果是这个编码问题导致。那这个可以屏蔽么?

    回复 2020-03-31 00:44
    1. 宁采陈
      宁采陈 博主

      那应该是主题里面的查询语句没对postgresql数据库做兼容。

      回复 2020-03-31 22:46
      1. jarome
        jarome

        是的。主题会自动创建一个字段。这个创建字段的一句在postgresql上是错误的

        回复 2020-04-03 14:07
  6. xsir
    xsir

    试试😆

    回复 2020-03-23 17:30
  7. Blue.
    Blue.

    😁

    回复 2020-02-01 15:46
  8. gordsky
    gordsky

    大神可以的

    回复 2020-01-29 14:25
  9. upuptop
    upuptop

    🐂🐂🐂🐂🐂🐂🐂🐂🐂🐂🐂🐂

    回复 2020-01-07 17:16
  10. test
    test

    😋11

    回复 2019-11-28 17:58
  11. 盖壮实
    盖壮实

    哈哈哈哈😋😌😍😘😙😜😝🤑🤓😎🤗🤡🤠😏😶😑😒🙄🤔😳😞😟😠😡😔😕☹️😣😖😫😤😮😱😨😯😦😢😥😪😓🤤😭😲🤥🤢🤧🤐😷🤒🤕😴💤

    回复 2019-10-21 21:37
  12. rmdzw.com
    rmdzw.com

    ⌚📱📲💻⌨️🖥️🖨️🖱️🖲️🕹️🎮🗜️💽📀💿🎥📽️📹🎬📸📷📼💾📞🎞️☎️📟📠📈📺📻⏰试试新货emoji

    回复 2019-08-23 21:20
  13. Samuel
    Samuel

    😀😁🤣😂😄😅😆😇😉😊🙂🙃☺️😋😌😍😘😙😜😝🤑🤓😎🤗🤡🤠😏😶😑😒🙄🤔😳😞😟😠😡😔😕☹️😣😖😫😤😮😱😨😯😦😢😥😪😓🤤😭😲🤥🤢🤧🤐😷🤒🤕😴💤
    完美,用上博主的主题,很漂亮,感谢!!保留了你全部的链接。

    回复 2019-08-23 10:22
    1. ty5466
      ty5466

      jkyuio

      回复 2020-04-13 19:24
    2. Samuel
      Samuel

      忘记说了,因为首页的相片用手机浏览会出现大小图片不一致,所以我修改了下,用CSS固定了个大小,看来起会统一点。
      display: block;
      width:100%;
      height: *rem;
      object-fit: cover;
      🤣🤣

      回复 2019-08-23 11:01
      1. 宁采陈
        宁采陈 博主

        采纳了,这个问题是当时开发主题时故意只限宽度的,因为当时想的是好不容易找的图,显示完整来欣赏更好。现在不同了,用的人多了。还是规矩点,主要突出文章标题好点,排版整整齐齐也很重要。👍

        回复 2019-08-23 23:47
  14. 有课
    有课

    瞅瞅

    回复 2019-08-21 22:51
  15. 青春
    青春

    修改完,评论区可以了,但是发文章显示的是'?'问号

    回复 2019-08-21 21:31
    1. 青春
      青春

      找到原因了,文章的表typecho_contents也得改

      回复 2019-08-21 22:03
      1. 青春
        青春

        博主大大有空的话可以搞一个评论区Emoji表情插件😜

        回复 2019-08-21 22:19
        1. 宁采陈
          宁采陈 博主

          空倒是有,就是人有点懒。。。

          回复 2019-08-21 23:58
          1. 青春
            青春

            博主大大的邮件推送用的那个插件啊

            回复 2019-08-22 20:33
            1. 青春
              青春

              我用LoveKKComment不勾选‘启用找回密码’ 后台下方有报错😂

              回复 2019-08-22 20:47
              1. 宁采陈
                宁采陈 博主

                是的,有些小问题。我现在也是在用该插件。

                2019-08-23 00:43