1、这两个方法的原理就是将字符集的某一段进行转换,不会影响中文在数据库中的存储
2、当然还可以用base64编码处理,但这样老数据就会不好处理了
3、原文查看https://segmentfault.com/q/1010000003711491
/**
* 对表情进行编码
*/
public static function emoji_encode($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);
}
/**
* 对表情进行解码
* @param unknown $str
* @return string|mixed
*/
public static function emoji_decode($str){
$text = json_encode($str); //暴露出unicode
$text = preg_replace_callback('/\\\\\\\\/i',function($str){
return '\\';
},$text); //将两条斜杠变成一条,其他不动
return json_decode($text);
}