Typecho 默认不支持 Emoji 表情,插入emoji表情竟然
Database Query Error
报错。 Emoji 是一种在 Unicode 位于u1F601-u1F64F区段的字符。超出了目前常用的 UTF-8 字符集的编码范围u0000-uFFFF。 在MySQL
中,UTF-8 只支持最多 3 个字节,而 Emoji 是 4 个字节。所以评论中带有 Emoji 表情才会报错。我们只需简单两步即可让 typecho 支持 emoji 表情评论,只要将默认的数据库编码utf8
修改为utf8mb4
即可。
全局插入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;
/** 定义数据库参数 */
$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);
修改好后保存即可。
- 解决Typecho带有Emoji表情Database Query Error报错的处理方法!-星泽V社