emoji 表情是扩展的 utf-16 编码
你可以贴出含有 emoji表情 的文字的 base64 编码串
看看能否帮你解决问题

解决方案 »

  1.   

    这个就是表情base64位保存后的数据。8J+YhPCfmIM= 。版大麻烦看看!.现在好多应用都支持这个表情输入,就是不知道怎么保存的。
      

  2.   

    应该说改用 utf8mb4 字符集就可以了,不知道你为什么不行
    考虑到文字中 emoji 字符并不多,可以用正则替换一下在存入
    $text = base64_decode('8J+YhPCfmIM=');
    echo $text = preg_replace_callback('/[\xf0-\xf7].{3}/', function($r) { return '@E' . base64_encode($r[0]);}, $text);
    @E8J+YhA==@E8J+Ygw==都会后逆转换一下就可以了
    $s = preg_replace_callback('/@E(.{6}==)/', function($r) {return base64_decode($r[1]);}, '@E8J+YhA==@E8J+Ygw==');
    var_dump(base64_decode('8J+YhPCfmIM=') == $s);
    bool(true)
      

  3.   

    是啊,很郁闷。网上都说只要设置为utf8mb4 就行,可我的就不行。mysql的版本是用的是5.6的。,wampserver环境。会不会是环境问题?
      

  4.   

    我也遇到这个问题,改成utfmb4  还是插入不进去,然后用了不是办法的办法,存储最原始的二进制,伤不起。