您好,登錄后才能下訂單哦!
小編給大家分享一下PHP開(kāi)發(fā)中涉及到emoji表情怎么處理,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
一般Mysql表設(shè)計(jì)時(shí),都是用UTF8字符集的。把帶有emoji的昵稱字段往里面insert一下就沒(méi)了,整個(gè)字段變成了空字符串。這是怎么回事呢?
原來(lái)是因?yàn)镸ysql的utf8字符集是3字節(jié)的,而emoji是4字節(jié),這樣整個(gè)昵稱就無(wú)法存儲(chǔ)了。這要怎么辦呢?我來(lái)介紹幾種方法
1、使用utf8mb4字符集
如果你的mysql版本>=5.5.3,你大可直接將utf8直接升級(jí)為utf8mb4字符集
這種4字節(jié)的utf8編碼可完美兼容舊的3字節(jié)utf8字符集,并且可以直接存儲(chǔ)emoji表情,是最好的解決方案
至于字節(jié)增大帶來(lái)的性能損耗,我看過(guò)一些評(píng)測(cè),幾乎是可以忽略不計(jì)的
2、使用base64編碼
如果你因?yàn)槟承┰驘o(wú)法使用utf8mb4的話,你還可以使用base64來(lái)曲線救國(guó)
使用例如base64_encode之類的函數(shù)編碼過(guò)后的emoji可以直接存儲(chǔ)在utf8字節(jié)集的數(shù)據(jù)表中,取出時(shí)decode一下即可
3、干掉emoji表情
emoji表情是個(gè)麻煩的東西,即使你能存儲(chǔ),也不一定能完美顯示。在iOS以外的平臺(tái)上,例如PC或者android。如果你需要顯示emoji,就得準(zhǔn)備一大堆emoji圖片并使用第三方前端類庫(kù)才行。即便如此,還是可能因?yàn)閑moji圖片不夠全而出現(xiàn)無(wú)法顯示的情況
在大多數(shù)業(yè)務(wù)場(chǎng)景下,emoji也不是非要不可的。我們可以適當(dāng)?shù)乜紤]干掉它,節(jié)約各種成本
經(jīng)過(guò)一番苦苦的google,終于找到靠譜能用的代碼:
// 過(guò)濾掉emoji表情 function filterEmoji($str) { $str = preg_replace_callback( '/./u', function (array $match) { return strlen($match[0]) >= 4 ? '' : $match[0]; }, $str); return $str; }
基本思想就是遍歷字符串中的每個(gè)字符,如果該字符的長(zhǎng)度為4個(gè)字節(jié),就將其刪除。
以上是PHP開(kāi)發(fā)中涉及到emoji表情怎么處理的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。