Typecho 默认不支持 Emoji 表情,这不是程序的锅,而是由于编码的问题造成,Emoji 是一种在 Unicode 位于u1F601-u1F64F区段的字符。这显然超出了目前常用的 UTF-8 字符集的编码范围u0000-uFFFF。在 MySQL 中,UTF-8 只支持最多 3 个字节,而 Emoji 是 4 个字节。所以评论中带有 Emoji 表情才会报错。
我们只需简单两步即可让 typecho 支持 emoji 表情评论,只要将默认的数据库编码 utf8 修改为 utf8mb4 即可。
1.修改评论内容字段的编码
使用数据库管理工具,找到 typecho_comments 评论表的 text 字段,将该字段的编码改为 utf8mb4_general_ci。
2.修改数据库配置文件
打开网站根目录数据库配置文件 config.inc.php
将 charset 的值由 utf8 改为 utf8mb4。
/** 定义数据库参数 */
$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);
修改好后保存即可。
完工!
????????????☺️??????????????????????????☹️?????????????????????????
可以在我博客留言测试一下哦!
?
厉害哈哈
博主有没有遇到在手机上评论出现 Database Query Error ,在电脑端是没问题的
只有文字也会报错
?
不错``
大佬,我是postgresql的数据库,切换主题就报了一个 Database Query Error 。这个应该怎么弄啊?如果是这个编码问题导致。那这个可以屏蔽么?
那应该是主题里面的查询语句没对postgresql数据库做兼容。
是的。主题会自动创建一个字段。这个创建字段的一句在postgresql上是错误的
遇到同样的问题 小白不知道该怎么解决
试试?
?
大神可以的
????????????
?11
哈哈哈哈??????????????????????????☹️?????????????????????????
⌚???⌨️?️?️?️?️?️??️?????️????????️☎️?????⏰试试新货emoji
????????????☺️??????????????????????????☹️?????????????????????????
完美,用上博主的主题,很漂亮,感谢!!保留了你全部的链接。
jkyuio
忘记说了,因为首页的相片用手机浏览会出现大小图片不一致,所以我修改了下,用CSS固定了个大小,看来起会统一点。
display: block;
width:100%;
height: *****rem;
object-fit: cover;
??
采纳了,这个问题是当时开发主题时故意只限宽度的,因为当时想的是好不容易找的图,显示完整来欣赏更好。现在不同了,用的人多了。还是规矩点,主要突出文章标题好点,排版整整齐齐也很重要。?
瞅瞅
修改完,评论区可以了,但是发文章显示的是'?'问号
找到原因了,文章的表typecho_contents也得改
博主大大有空的话可以搞一个评论区Emoji表情插件?
空倒是有,就是人有点懒。。。
博主大大的邮件推送用的那个插件啊
我用LoveKKComment不勾选‘启用找回密码’ 后台下方有报错?
是的,有些小问题。我现在也是在用该插件。