前言
微信开发,解决用户昵称带emoji图标导致无法正常保存昵称到mysql问题(我的数据库是mysql5.6),下面是参考网上大佬代码给出的解决方案。
解决方案
/**
*去除用户昵称特殊字符(主要针对特殊符号和emoji表情)
*/
public function delNicknameUnicode($str)
{
if (!is_string($str)) return $str;
if (empty($str) ) return '';
$text = json_encode($str); //暴露出unicode
$text = preg_replace_callback("/(\\\u[ed][0-9a-f]{3})/i", function ($str) {
return "";
// return addslashes($str[0]);
}, $text); //将emoji的unicode留下,其他不动,这里的正则比原答案增加了d,因为我发现我很多emoji实际上是\ud开头的,反而暂时没发现有\ue开头。
return json_decode($text);
}
/**
*转义用户昵称(主要针对特殊符号和emoji表情)
*/
public function nicknameUnicodeEncode($str)
{
if (!is_string($str)) return $str;
if (empty($str) ) 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);
}
/**
*解码上面的转义
*/
public function nicknameUnicodeDecode($str)
{
$text = json_encode($str);
//暴露出unicode
$text = preg_replace_callback('/\\\\\\\\/i', function ($str) {
//反转义,去除多余的斜杠
return '\\';
}, $text);
return json_decode($text);
}