mysql 用的 字符集 为utf8的 只能保存三个字节 而 表情是四个字节 当把表情 保存到数据库 就会报错,这时候 就需要一下的操作
方案一、
修改 字段 字符集
ALTER TABLE `ben_review` CHANGE `reviewContent` `reviewContent` VARCHAR( 255 ) CHARACTER SET utf8mb4 COLLATE utf8mb4_estonian_ci NOT NULL ;
修改表 字符集
ALTER TABLE 表名 DEFAULT CHARACTER SET UTF8MB4 COLLATE UTF8MB4_general_ci;
修改数据库字符集
ALTER TABLE 表名 DEFAULT CHARACTER SET UTF8MB4 COLLATE UTF8MB4_general_ci;
方案二 、
转码 表情
//表情包处理操作
function userTextEncode($str){
if(!is_string($str))return $str;
if(!$str || $str=='undefined')return '';
$text = json_encode($str); //暴露出unicode
$text = preg_replace_callback("/(\\\u[ed][0-9a-f]{3})/i",function($str){
return addslashes($str[0]);
},$text); //将emoji的unicode留下,其他不动,这里的正则比原答案增加了d,因为我发现我很多emoji实际上是\ud开头的,反而暂时没发现有\ue开头。
return json_decode($text);
}
//解析表情包
function userTextDecode($str){
$text = json_encode($str); //暴露出unicode
$text = preg_replace_callback("/(\\\u[ed][0-9a-f]{3})/i",function($str){
return stripslashes($str[0]);
},$text); //将两条斜杠变成一条,其他不动
return json_decode($text);
}