悠悠楠杉
网站页面
Typecho用的是 UTF-8 的编码,在 MySQL 中,UTF-8 只支持最多 3 个字节,而 emoji 是 4 个字节,所以就会出现一些问题。
知道问题所在以后就好办多了:
1、进入PhpMyadmin,选择对应的数据库,选择操作——排序规则——选择utf8mb4_general_ci
并执行。
2、选择SQL-复制下面sql语句代码-点击右下角执行。
注意数据库一定要和网站的数据库对应。
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;
3、修改 Typecho 配置文件中数据库定义参数中的 charset
为 utf8mb4
:
$db->addServer(array (
'host' => localhost,
'user' => 'us',
'password' => 'my_password',
'charset' => 'utf8mb4', //修改这一行
'port' => 3306,
'database' => 'us'
), Typecho_Db::READ | Typecho_Db::WRITE);
搞定~
啊对了,对于不支持 emoji 的设备上大概会显示为框框吧,但至少不会像之前直接毫无人性的砍掉 (Mysql 的锅) emoji 之后的内容要好上太多了。。。