解决Typecho带有Emoji表情Database Query Error报错的处理方法!-星泽V社

本文阅读 2 分钟
首页 干货教程 正文

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


6342745e4115d.png

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

1.修改评论内容字段的编码
使用数据库管理工具,找到 typecho_contents 评论表的 text 字段,将该字段的编码改为 utf8mb4_general_ci。

6342746935df0.png


如果是评论不能使用就找到 typecho_comments 评论表的 text 字段,将该字段的编码改为 utf8mb4_general_ci。


都改了算了,我全给改了,都改了全局都能插入emoji表情等。

运行以下代码:

alter table typecho_comments convert to character set utf8mb4 collate utf8mb4_general_ci;
alter table typecho_contents convert to character set utf8mb4 collate utf8mb4_general_ci;
alter table typecho_fields convert to character set utf8mb4 collate utf8mb4_general_ci;
alter table typecho_metas convert to character set utf8mb4 collate utf8mb4_general_ci;
alter table typecho_options convert to character set utf8mb4 collate utf8mb4_general_ci;
alter table typecho_relationships convert to character set utf8mb4 collate utf8mb4_general_ci;
alter table typecho_users convert to character set utf8mb4 collate 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);

修改好后保存即可。

? ? ? ? ? ? ? ? ? ? ? ? ?
nice~

本文来自投稿,如若转载,请注明出处:
【全新版本】新拟态个人主页V2.0-星泽V社
« 上一篇 09-19
静拂时光 清秋絮语 | 关于我的一些想法...
下一篇 » 09-20

发表评论

V注册会员 L评论等级
R3 条回复
  1. a1216V :
    2022-07-10     Android /    Chrome

  2. a1216V :
    2022-07-10     Android /    Chrome

    ?

没有更多评论了

作者信息

动态快讯

    请配置好页面缩略名选项

热门文章

最多点赞

标签TAG

热评文章