摘要:最近幾個月做微信開發(fā)比較多,存儲微信昵稱必不可少可這萬惡的微信支持表情做昵稱,這就有點蛋疼了一般表設(shè)計時,都是用字符集的。
最近幾個月做微信開發(fā)比較多,存儲微信昵稱必不可少
可這萬惡的微信支持emoji表情做昵稱,這就有點蛋疼了
一般Mysql表設(shè)計時,都是用UTF8字符集的。把帶有emoji的昵稱字段往里面insert一下就沒了,整個字段變成了空字符串。這是怎么回事呢?
原來是因為Mysql的utf8字符集是3字節(jié)的,而emoji是4字節(jié),這樣整個昵稱就無法存儲了。這要怎么辦呢?我來介紹幾種方法
1、使用utf8mb4字符集如果你的mysql版本>=5.5.3,你大可直接將utf8直接升級為utf8mb4字符集
這種4字節(jié)的utf8編碼可完美兼容舊的3字節(jié)utf8字符集,并且可以直接存儲emoji表情,是最好的解決方案
至于字節(jié)增大帶來的性能損耗,我看過一些評測,幾乎是可以忽略不計的
如果你因為某些原因無法使用utf8mb4的話,你還可以使用base64來曲線救國
使用例如base64_encode之類的函數(shù)編碼過后的emoji可以直接存儲在utf8字節(jié)集的數(shù)據(jù)表中,取出時decode一下即可
emoji表情是個麻煩的東西,即使你能存儲,也不一定能完美顯示。在iOS以外的平臺上,例如PC或者android。如果你需要顯示emoji,就得準(zhǔn)備一大堆emoji圖片并使用第三方前端類庫才行。即便如此,還是可能因為emoji圖片不夠全而出現(xiàn)無法顯示的情況
在大多數(shù)業(yè)務(wù)場景下,emoji也不是非要不可的。我們可以適當(dāng)?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é),就將其刪除。
轉(zhuǎn)載自:pein0119
像我最近做的一個小項目,就是用方法3解決的,方便省事
本文同時刊登于我的博客 超能小紫,如果喜歡請常來玩哦
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://specialneedsforspecialkids.com/yun/21690.html
摘要:導(dǎo)語本文源于微信游戲春節(jié)王者搖心愿活動英雄語音祝福自定義輸入模塊開發(fā)過程,對踩過的前端字符編碼的坑進(jìn)行記錄總結(jié)。只規(guī)定了字符編碼,而并沒有規(guī)定具體的編碼方式。 導(dǎo)語 本文源于微信游戲春節(jié)王者搖心愿活動英雄語音祝福自定義輸入模塊開發(fā)過程,對踩過的前端字符編碼的坑進(jìn)行記錄總結(jié)。 Unicode 字符 Unicode(中文:萬國碼、國際碼、統(tǒng)一碼、單一碼)是計算機科學(xué)領(lǐng)域里的一項業(yè)界標(biāo)準(zhǔn)。它...
摘要:二是考慮到某些表情包現(xiàn)在可能并不想用,但代碼刪來刪去可能會很麻煩,所以提供了一個是否啟用的接口。 很久沒有寫文章了,說實話本人現(xiàn)在受困于五月病已經(jīng)快變成一條死咸魚了(T_T),本次就當(dāng)寫一個簡單的js插件教程了。本項目的代碼相對比較簡單,至于里面有些變量命名的問題就請你們不要吐槽了Σ(?д?lll)(好的,我承認(rèn)我英語就小學(xué)水平好吧。除了hello和goodbye其他的都不會了____...
閱讀 1798·2021-11-24 10:21
閱讀 1208·2021-09-22 15:25
閱讀 3170·2019-08-30 15:55
閱讀 708·2019-08-30 15:54
閱讀 3461·2019-08-30 14:20
閱讀 1659·2019-08-30 14:06
閱讀 638·2019-08-30 13:11
閱讀 3144·2019-08-29 16:43