Emoji
Emoji
表情随着IOS
的普及和微信的支持越来越常见,比如这些比较常见的表情:⭐️ ✨ ⚡️。所谓Emoji
就是一种在Unicode
位于\u1F601-\u1F64F
区段的字符。这个显然超过了目前常用的UTF-8
字符集的编码范围u0000-uFFFF
。在 MySQL
中,UTF-8
只支持最多 3 个字节,而 emoji
是 4 个字节。
原理
Typecho
默认不支持emoji
表情,其实不是程序的锅,而是由于编码的问题,只需要将默认的数据库编码utf8
修改为utf8mb4
即可,当然别忘了,utf8mb4
编码只有在PHP5.5
以后才支持。
目标
简单两步即可让typecho
支持emoji
方法
1.修改数据库编码
进入PhpMyadmin
,选择您的数据库,操作 → 整理 → 选择utf8mb4_unicode_ci
2.修改数据库表编码
直接运行以下sql
语句
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;
3.修改数据库配置文件
网站根目录数据库配置文件config.inc.php
,下面是示例:
$db->addServer(array (
'host' => localhost,
'user' => 'youruser',
'password' => 'yourpassword',
'charset' => 'utf8mb4', //修改这一行 utf8 -> utf8mb4
'port' => 3306,
'database' => 'yourdatabase'
), Typecho_Db::READ | Typecho_Db::WRITE);
2 条评论
这样做无法保证最终效果,还差那么一些步骤。
第一步有点模糊,需要找到转换utf8mb4_unicode_ci 这个的窗口