微信开发,解决用户昵称带emoji图标导致无法正常保存昵称到mysql问题

前言

微信开发,解决用户昵称带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);
    }