使Typecho支持Emoji表情
in BlogMySQLWeb with 0 comment

使Typecho支持Emoji表情

in BlogMySQLWeb with 0 comment

最近发现一个好看的typecho主题,折腾了一番,差不多整理好了!

Emoji 表情随着 iOS 的普及和微信的支持越来越常见,比如这些比较常见的表情:😀 😃 😄 😁 😆 😅 😂 🤣。所谓 Emoji 就是一种在 Unicode 位于 u1F601-u1F64F 区段的字符。这个显然超过了目前常用的 UTF-8 字符集的编码范围 u0000-uFFFF 。在 MySQL 中,UTF-8 只支持最多 3 个字节,而 emoji 是 4 个字节,Typecho 默认不支持 emoji 表情,其实不是程序的锅,而是由于编码的问题,只需要将默认的数据库编码 utf8 修改为 utf8mb4 即可,当然别忘了,utf8mb4 编码只有在 PHP 5.5 以后才支持的哦。

具体操作如下:

修改数据库编码

进入 PhpMyadmin ,选择您的数据库,操作-----整理----选择 utf8mb4_unicode_ci
或终端登录mysql:mysql -uroot -p123456 db_name
执行修改sql:

alter database db_name  default character set 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

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

补充说明

上面的操作是参考YephyBlog的网站修改的,但是我在处理的时候发现转换表的字符集时候会报错:
ERROR 1071 (42000): Specified key was too long; max key length is 767 bytes
这个原因是索引列在转换后,索引重建超过最大长度了。

解决方法如下:

alter table typecho_users modify mail varchar(150);
alter table typecho_contents modify slug varchar(150);
alter table typecho_fields modify name varchar(150);
alter table typecho_metas modify slug varchar(150);

这样之后,就可以做表的字符集转换了。

Responses
点击这里给我发消息
嘿!有什么能帮到您的吗?