首頁  >  文章  >  後端開發  >  php專案中使用emoji表情的解決方法

php專案中使用emoji表情的解決方法

*文
*文原創
2018-01-02 13:14:042303瀏覽

日常中常會發生用戶發送的內容包含emoji表情,未經處理,在顯示時就是亂碼。所以本文介紹在PHP微信開發中涉及emoji表情的幾種處理方法。希望對大家有幫助。

背景

做微信開發的時候就會發現,儲存微信暱稱不可或缺。

可這萬惡的微信支援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;
 }

相關推薦:

php如何產生mysql資料字典

#php實作單字統計功能

PHP如何處理二進位資料#

以上是php專案中使用emoji表情的解決方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn