App下載
話題 首頁 > MySQL 教程 > MySQL 教程話題列表 > 詳情

如何處理emoji表情?

精華
胖大叔 2016-10-20 06:01:02 瀏覽(6375) 回復(4) 贊(0)
萬惡的微信支持emoji表情做昵稱,這就有點蛋疼了,一般mysql表設(shè)計時,都是用UTF8字符集的。把帶有emoji的昵稱字段往里面insert一下就沒了,整個字段變成了空字符串~嗚嗚嗚嗚~
mysql

回答(4)

LOVEME96 2016-10-21

Mysql的utf8字符集是3字節(jié)的,而emoji是4字節(jié),這樣整個昵稱就無法存儲了。

這個問題的解決方法有三個:

1、使用utf8mb4字符集

如果你的mysql版本>=5.5.3,你大可直接將utf8直接升級為utf8mb4字符集

這種4字節(jié)的utf8編碼可完美兼容舊的3字節(jié)utf8字符集,并且可以直接存儲emoji表情,是最好的解決方案 至于字節(jié)增大帶來的性能損耗,我看過一些評測,幾乎是可以忽略不計的

2、使用Base64編碼

如果你因為某些原因無法使用utf8mb4的話,你還可以使用base64來曲線救國

使用例如base64_encode之類的函數(shù)編碼過后的emoji可以直接存儲在utf8字節(jié)集的數(shù)據(jù)表中,取出時decode一下即可

3、干掉emoji表情

emoji表情是個麻煩的東西,即使你能存儲,也不一定能完美顯示。 在iOS以外的平臺上,例如PC或者android。如果你需要顯示emoji,就得準備一大堆emoji圖片并使用第三方前端類庫才行。即便如此,還是可能因為emoji圖片不夠全而出現(xiàn)無法顯示的情況

在大多數(shù)業(yè)務(wù)場景下,emoji也不是非要不可的。我們可以適當?shù)乜紤]干掉它,節(jié)約各種成本 經(jīng)過一番苦苦的google,終于找到靠譜能用的代碼:

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

               
     return $str;
 }
?>

基本思想就是遍歷字符串中的每個字符,如果該字符的長度為4個字節(jié),就將其刪除。

一筆荒蕪 2018-05-31

大神在哪里呀,大神在哪里呀,大神在哪里呀.

1144100656 2018-05-31

吃瓜群眾,坐等大神來解決。。。。。

1152696398 2018-05-31

有同樣等問題咋解決,只能慢慢等大神啦.留名留名。。

要回復,請先登錄 或者注冊