php 实现emoji遇到的棘手问题,很棘手!

发布于 2022-09-01 17:16:57 字数 818 浏览 14 评论 0

function str_emoji($dir,$str){
  if($dir){
    $str=json_encode($str);
    $str=preg_replace('#(\\\ud[0-9a-f]{3}|\\\u2(6|7)[0-9a-f]{2})#ie','addslashes("\\1")',$str);
    //emoji 5.0后,一个表情由两个字符组成
    $str=json_decode($str);
  }else{
    $str=preg_replace('#(u[0-9a-f]{4}u[0-9a-f]{4})#ie','iconv("UCS-2","UTF-8",pack("H4","\\1"))',$str);
    //此正则匹配ue415ue415形式的数据
    //不能将二进制转成\xf0\x9f\x98\x83形式的UTF-8
  }
  return $str;
};
//写进数据库
$content=str_emoji(true,$content);
//读取数据库
$content=str_emoji(false,$content);

下面问题来了。

iconv("UCS-2","UTF-8",pack("H4","\\1")) 不能将二进制专程UTF-8,怎么破????
另:数据库版本不能直接存储emoji,升级数据库是肯定不可行的方案。

参考文章:http://blog.mc-zone.me/article/322

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(3

屋檐 2022-09-08 17:16:57

存数据库的时候 base_encode64() 取得的时候base_decode64()

昔日梦未散 2022-09-08 17:16:57

mysql编码选择utf8mb4即可

疯狂的代价 2022-09-08 17:16:57

数据库是mysql吧,把数据库和字段编码设置为utf8mb4,可以直接保存表情字符

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文