一、判断字符串中是否含有 emoji 表情

三个 PHP 内置函数:

mb_strlen

mixed mb_strlen ( string $str [, string $encoding = mb_internal_encoding() ] )//返回具有 encoding 编码的字符串 str 包含的字符数。
多字节的字符被计为 1。
//如果给定的 encoding 无效则返回 FALSE。
mb_substr

stringmb_substr(string$str,int$start[,int$length=NULL[,string$encoding=mb_internal_encoding()]])//根据字符数实行一个多字节安全的 substr()操作。
位置是从 str 的开始位置进行计数。
第一个字符的位置是0。
第二个字符的位置是 1。
//mb_substr()函数根据start和length参数返回str中指定的部分。
strlen

intstrlen(string$string)//返回给定的字符串 string 的长度。

函数如下:

emojiforphpPHP处置字符中的emoji脸色断定/移除/存储 React

function haveEmojiChar($str){ $mbLen=mb_strlen($str);$strArr=[];for($i=0;$i<$mbLen;$i++){ $strArr[]=mb_substr($str,$i,1,'utf-8'); if(strlen($strArr[$i])>=4){ returntrue; }} returnfalse;}

二、移除字符串中的 emoji 表情

函数如下:

function removeEmojiChar($str){ $mbLen=mb_strlen($str); $strArr=[]; for($i=0;$i<$mbLen;$i++){ $mbSubstr=mb_substr($str,$i,1,'utf-8'); if(strlen($mbSubstr)>=4){ continue; } $strArr[]=$mbSubstr; } returnimplode('',$strArr);}

三、含有 emoji 表情的字符串在 MySQL 中的储存

1、MySQL 中利用 utf8mb4 字符集。

2、PHP 对字符串进行 base64 编码,从数据库中取出时再对字符串进行解码。

3、直接移除字符串中的 emoji 表情(该方法大略粗暴)