Typecho 中 无法使用 Emoji 表情的解决方法

in 技巧分享 with 0 comment

Emojis

其实不光是 Typecho,很多程序都可以这么做,主要就是一个数据库编码的问题。

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

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

修改评论内容字段的编码

使用数据库管理工具,将 charset 改为 utf8mb4

alter table typecho_comments convert to character set utf8mb4 collate utf8mb4_unicode_ci;
alter table typecho_contents convert to character set utf8mb4 collate utf8mb4_unicode_ci;
alter table typecho_fields convert to character set utf8mb4 collate utf8mb4_unicode_ci;
alter table typecho_metas convert to character set utf8mb4 collate utf8mb4_unicode_ci;
alter table typecho_options convert to character set utf8mb4 collate utf8mb4_unicode_ci;
alter table typecho_relationships convert to character set utf8mb4 collate utf8mb4_unicode_ci;
alter table typecho_users convert to character set utf8mb4 collate utf8mb4_unicode_ci;

修改数据库配置文件

打开网站根目录数据库配置文件 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);

修改好后保存即可,然后就可正常使用 Emoji 了,试试看吧 😁

Responses