让 Typecho 支持 emoji 表情显示

偶然发现 Typecho 由于数据库字符集的原因,无法显示 emoji 表情,其实简单修改数据库字符集就可以解决这个问题了。

其实也不能说 Typecho 不支持,毕竟是字符集的锅,跟 Typecho 没有关系。之前用的是 UTF-8 的编码,在 MySQL 中,UTF-8 只支持最多3个字节,而 emoji 是4个字节,所以就出现无法显示的问题。

修改数据库 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;

修改 Typecho 配置文件 config.inc.php 中数据库定义参数中的 charset 为 utf8mb4

$db->addServer(array (
  'host'      =>  'localhost',
  'user'      =>  'root',
  'password'  =>  'password',
  'charset'   =>  'utf8mb4', //修改这一行
  'port'      =>  3306,
  'database'  =>  'dbname'
), Typecho_Db::READ | Typecho_Db::WRITE);
Typecho_Db::set($db);

对了,对于不支持 emoji 的设备上大概是会显示为框框吧,当然不同设备对于 emoji 的渲染也是不一样的,所以看到的 emoji 表情也应该是不一样的😂😂😂

参考:hran

标签: Typecho

发表评论: