Loading... 今天写文章的时候插入emoji表情竟然「Database Query Error」报错,Typecho 默认不支持 Emoji 表情,这不是程序的锅,而是由于编码的问题造成。 Emoji 是一种在 Unicode 位于u1F601-u1F64F区段的字符。这显然超出了目前常用的 UTF-8 字符集的编码范围u0000-uFFFF。 在 [MySQL]中,UTF-8 只支持最多 3 个字节,而 Emoji 是 4 个字节。所以评论中带有 Emoji 表情才会报错。 ![](<a href="https://smjc.cc/usr/uploads/2023/05/4111377969.jpeg)" title="https://smjc.cc/usr/uploads/2023/05/4111377969.jpeg)">https://smjc.cc/usr/uploads/2023/05/4111377969.jpeg)</a> 我们只需简单两步即可让 typecho 支持 emoji 表情评论,只要将默认的[数据库]编码 utf8 修改为 utf8mb4 即可。 **1.修改评论内容字段的编码** 使用[数据库管理]工具,找到 typecho_contents 评论表的 text 字段,将该字段的编码改为 utf8mb4_general_ci。 ![](https://smjc.cc/usr/uploads/2023/05/1039635906.png) 如果是评论不能使用就找到 typecho_comments 评论表的 text 字段,将该字段的编码改为 utf8mb4_general_ci。 *都改了算了,我全给改了,都改了全局都能插入emoji表情等。* ** 运行以下代码:** ```javascript 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** 。 ```javascript /** 定义数据库参数 */ $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); ``` 复制 修改好后保存即可。 最后修改:2023 年 05 月 31 日 © 允许规范转载 打赏 赞赏作者 支付宝微信 赞 如果觉得我的文章对你有用,请随意赞赏