Emoji就是一种在Unicode位于u1F601-u1F64F区段的字符。在 MySQL 中,UTF-8只支持最多 3 个字节,而 emoji 是 4 个字节。

因此由于编码的问题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 为 utf8mb4

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

大功告成,修改过后评论和文章都能够正常的输入输出emoji了😉