emoji保存到mysql php_mysql存入emoji表情现在为?
发布日期:2021-06-24 11:28:36 浏览次数:2 分类:技术文章

本文共 1253 字,大约阅读时间需要 4 分钟。

mysql存入emoji表情现在为???.按网上的说法把mysql的字符集改为utf8mb4,还是无效,显示为乱码。。请问有人遇到过吗?

回复讨论(解决方案)

emoji 表情是扩展的 utf-16 编码

你可以贴出含有 emoji表情 的文字的 base64 编码串

看看能否帮你解决问题

emoji 表情是扩展的 utf-16 编码

你可以贴出含有 emoji表情 的文字的 base64 编码串

看看能否帮你解决问题

这个就是表情base64位保存后的数据。8J+YhPCfmIM= 。版*烦看看!.现在好多应用都支持这个表情输入,就是不知道怎么保存的。

应该说改用 utf8mb4 字符集就可以了,不知道你为什么不行

考虑到文字中 emoji 字符并不多,可以用正则替换一下在存入$text = base64_decode('8J+YhPCfmIM=');echo $text = preg_replace_callback('/[\xf0-\xf7].{3}/', function($r) { return '@E' . base64_encode($r[0]);}, $text);@E8J+YhA==@E8J+Ygw==

都会后逆转换一下就可以了

$s = preg_replace_callback('/@E(.{6}==)/', function($r) {return base64_decode($r[1]);}, '@E8J+YhA==@E8J+Ygw==');var_dump(base64_decode('8J+YhPCfmIM=') == $s);bool(true)

应该说改用 utf8mb4 字符集就可以了,不知道你为什么不行

考虑到文字中 emoji 字符并不多,可以用正则替换一下在存入$text = base64_decode('8J+YhPCfmIM=');echo $text = preg_replace_callback('/[\xf0-\xf7].{3}/', function($r) { return '@E' . base64_encode($r[0]);}, $text);@E8J+YhA==@E8J+Ygw==

都会后逆转换一下就可以了

$s = preg_replace_callback('/@E(.{6}==)/', function($r) {return base64_decode($r[1]);}, '@E8J+YhA==@E8J+Ygw==');var_dump(base64_decode('8J+YhPCfmIM=') == $s);bool(true)

是啊,很郁闷。网上都说只要设置为utf8mb4 就行,可我的就不行。mysql的版本是用的是5.6的。。。。,wampserver环境。会不会是环境问题?

楼主,我也遇到相同的问题了,请问你最后怎么解决的?

f68f2add0b68e4f9810432fce46917b7.png

本文原创发布php中文网,转载请注明出处,感谢您的尊重!

转载地址:https://blog.csdn.net/weixin_32503531/article/details/113280980 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!

上一篇:c++ 連接mysql_C++ 连接MySql
下一篇:mysql中空值运算_MySQL数据库之Mysql中空字符和空值的区别

发表评论

最新留言

表示我来过!
[***.240.166.169]2024年04月03日 21时36分51秒

关于作者

    喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!

推荐文章