微信开发,解决用户昵称带emoji图标导致无法正常保存昵称到mysql问题(我的数据库是mysql5.6)

微信开发,解决用户昵称带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);
    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

爱折腾的小码农

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值