最近几个月做微信开发比较多,存储微信昵称必不可少

可这万恶的微信支持emoji表情做昵称,这就有点蛋疼了

一般Mysql表设计时,都是用UTF8字符集的。把带有emoji的昵称字段往里面insert一下就没了,整个字段变成了空字符串。这是怎么回事呢?

原来是因为Mysql的utf8字符集是3字节的,而emoji是4字节,这样整个昵称就无法存储了。这要怎么办呢?我来介绍几种方法

1、使用utf8mb4字符集

如果你的mysql版本>=5.5.3,你大可直接将utf8直接升级为utf8mb4字符集

这种4字节的utf8编码可完美兼容旧的3字节utf8字符集,并且可以直接存储emoji表情,是最好的解决方案

至于字节增大带来的性能损耗,我看过一些评测,几乎是可以忽略不计的

2、使用base64编码

如果你因为某些原因无法使用utf8mb4的话,你还可以使用base64来曲线救国

使用例如base64_encode之类的函数编码过后的emoji可以直接存储在utf8字节集的数据表中,取出时decode一下即可

3、干掉emoji表情

emoji表情是个麻烦的东西,即使你能存储,也不一定能完美显示。在iOS以外的平台上,例如PC或者android。如果你需要显示emoji,就得准备一大堆emoji图片并使用第三方前端类库才行。即便如此,还是可能因为emoji图片不够全而出现无法显示的情况

在大多数业务场景下,emoji也不是非要不可的。我们可以适当地考虑干掉它,节约各种成本

经过一番苦苦的google,终于找到靠谱能用的代码:

// 过滤掉emoji表情function filterEmoji($str){    $str = preg_replace_callback(            '/./u',            function (array $match) {                return strlen($match[0]) >= 4 ? '' : $match[0];            },            $str);     return $str; }

基本思想就是遍历字符串中的每个字符,如果该字符的长度为4个字节,就将其删除。

更多相关文章

  1. PHP字节码缓存和内置服务器
  2. 2021各公司春招求职上岸大礼包! 春招一次上岸,阿里/字节/华为/腾
  3. 年末最新整理:阿里、腾讯、字节、华为、百度等大厂Android岗面经
  4. 和字节跳动面试官学长聊了聊人生~
  5. Java 中字符集的编解码
  6. HTML H5之ASCII 代码转义字符集实体编号
  7. 值得收藏的正则表达式(匹配中文字符、匹配双字节字符、匹配HTML标
  8. 我可以在运行PHP的64位系统上将PHP_INT_SIZE定义为4个字节吗?
  9. PHP字节单位转换

随机推荐

  1. android studio 快捷键描述和设置
  2. Android package属性、package name和App
  3. android 输入对话框 确认对话框
  4. adb通过wifi连接android设备的方法
  5. android字体大小多屏幕适配
  6. android 虚拟按键源码流程分析
  7. android SimpleOnGestureListener详解
  8. Android(安卓)自定义对话框
  9. Android 模拟器 HAXM硬件加速安装
  10. 关于服务端设置了IPV6时,Android请求网络