Typecho:修改数据库支持 emoji 表情字符

此文章发布于 37 个月前,部分信息可能已经过时,请自行斟酌确认。

关于 Emoji

Emoji 表情随着 IOS 的普及和微信的支持越来越常见,比如这些比较常见的表情:⭐️ ✨ ⚡️。所谓Emoji就是一种在 Unicode 位于\u1F601-\u1F64F 区段的字符。这个显然超过了目前常用的UTF-8字符集的编码范围u0000-uFFFF。在 MySQL 中,UTF-8 只支持最多 3 个字节,而 emoji4 个字节。

Typecho 支持 emoji 方法

1、修改数据库编码

  • 进入PhpMyadmin,选择您的数据库,操作 → 排序规则 → 选择 utf8mb4_unicode_ci
  • 同时选中更改所有表排序规则更改所有表列的排序规则
  • 然后点击执行

20210320_145337.png

当然也可以通过 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;

2、修改数据库配置文件

修改网站根目录配置文件config.inc.php如下:

$db->addServer(array (
  'host'      =>  localhost,
  'user'      =>  'root',
  'password'  =>  '123456',
  'charset'   =>  'utf8mb4', //将默认的utf8修改为utf8mb4
  'port'      =>  3306,
  'database'  =>  'weiku.co'
), Typecho_Db::READ | Typecho_Db::WRITE);

🎉完成。

参考资料

https://blog.laoooo.cn:88/emoji.html

最后修改:2021 年 03 月 20 日 02 : 58 PM
如果觉得我的文章对你有用,请随意赞赏

发表评论