发布于 1970-01-01 08:00
  • 14 个回答
    • 我是这么玩儿的

      <?php
      //处理名字的emoji符号
              $tmpStr = json_encode($text); //暴露出unicode
              $tmpStr = preg_replace("#(\\\ue[0-9a-f]{3})#ie","addslashes('\\1')",$tmpStr); //将emoji的unicode留下,其他不动
              $text = json_decode($tmpStr);
              return $text;
      2022-12-01 09:14 回答
    • 给一个标准的解决方案:

      1. mysql的版本必须为v5.5.3或更高

      2. 把数据库的编码改成utf8mb4 -- UTF-8 Unicode

      3. 然后需要存储emoji表情的字段选择utf8mb4_general_ci

      4. 数据库连接也需要改为utf8mb4

      设置完成后,应该可以看到如下类似字符集设置结果。那么可以直接的存入数据库,无需做任何额外的事情了。

      mysql> SHOW VARIABLES WHERE Variable_name LIKE 'character\_set\_%' OR Variable_name LIKE 'collation%';  
      +--------------------------+--------------------+  
      | Variable_name            | Value              |  
      +--------------------------+--------------------+  
      | character_set_client     | utf8mb4            |  
      | character_set_connection | utf8mb4            |  
      | character_set_database   | utf8mb4            |  
      | character_set_filesystem | binary             |  
      | character_set_results    | utf8mb4            |  
      | character_set_server     | utf8mb4            |  
      | character_set_system     | utf8               |  
      | collation_connection     | utf8mb4_unicode_ci |  
      | collation_database       | utf8mb4_unicode_ci |  
      | collation_server         | utf8mb4_unicode_ci |  
      +--------------------------+--------------------+  
       rows in set (0.00 sec) 
      2022-12-01 09:14 回答
    • 我在做微信公众平台开发时遇到过这个问题,微信用户的昵称可以包含表情(坑爹- -!)。于是我就将整个昵称转换成HEX字符串存在MySQL中,目前用户1W+,系统稳定,题主可以参考一下此方案。

      MySQL支持hex() and unhex()函数。Java可以使用org.apache.commons.codec.binary.Hex工具类。其他语言也有相应的方法。

      2022-12-01 09:14 回答
    • 试试微博或qq里面的那种方式?用简单的编码来映射,比如微笑可以用 [wx]/wx 。不过表情多了之后4个字符不怎么够用。。。

      2022-12-01 09:14 回答
    • urldecode
      我看了一下 decode 的源码,应该是不会出现问题。

      只要没有 % 解码后肯定还是原来的字符(串),有 % 会出现两种情况,一种是解码成功,这个时候肯定就不是原来的字符串了,一种是解码失败,抛出异常(其实这个异常可以作为是否 encode的标准)。

      解码还算是比较严格吧,作为用户名的情况下 出现 % 还解码成功的概率比较小吧,对于这部分你可以手动改数据库,应该不会有很多。

      2022-12-01 09:14 回答
    • 你试试这个函数,之前弄微信自定义菜单的时候,也接触过Emoji表情,当时看到用的这个函数把Emoji表情的编码给转换了。

      function utf8_bytes($cp) {
          if ($cp > 0x10000){
              # 4 bytes
              return    chr(0xF0 | (($cp & 0x1C0000) >> 18)).
              chr(0x80 | (($cp & 0x3F000) >> 12)).
              chr(0x80 | (($cp & 0xFC0) >> 6)).
              chr(0x80 | ($cp & 0x3F));
          }else if ($cp > 0x800){
              # 3 bytes
              return    chr(0xE0 | (($cp & 0xF000) >> 12)).
              chr(0x80 | (($cp & 0xFC0) >> 6)).
              chr(0x80 | ($cp & 0x3F));
          }else if ($cp > 0x80){
              # 2 bytes
              return    chr(0xC0 | (($cp & 0x7C0) >> 6)).
              chr(0x80 | ($cp & 0x3F));
          }else{
              # 1 byte
              return chr($cp);
          }
      }
      2022-12-01 09:14 回答
      1. 使用BOLO类型

      2. 将数据库编码改为 utf8mb4

      2022-12-01 09:14 回答
    • 我这个刚解决的这个问题(后端是java实现的,数据库Mysql),供参考。
      1、修改存储emoji字段编码,例如放在username字段中:

          ALTER TABLE user CHANGE username username VARCHAR(128) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci default null;

      2、java在执行数据库插入、更新操作前,要先执行 sql语句"set names utf8mb4" 语句。

      2022-12-01 09:14 回答
    • https://github.com/iamcal/php-emoji
      我是用这个处理的~

      2022-12-01 09:14 回答
    • 2022-12-01 09:14 回答
    • 有一种编码叫 utfmb4,支持 4 位长度的 utf8 编码

      喏,你的 MySQL 版本必须为 5.5 以上的

      2022-12-01 09:14 回答
    • 不用转,直接数据库转成utf8mb4, 我以前就是这么干的

      2022-12-01 09:14 回答
    • 不用更改整个数据库的把。。。create xxx() charset=utf8mb4 单表 utf8mb4就行了把

      2022-12-01 09:14 回答
    • 因为我的项目中需要对字数有限制的需求,涉及到逐字计数,在这基础上我增加了emoji的功能完美实现。你需要代码的话请再告诉我,我提供给你。

      2022-12-01 09:14 回答
    撰写答案
    今天,你开发时遇到什么问题呢?
    立即提问
    PHP1.CN | 中国最专业的PHP中文社区 | PNG素材下载 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
    Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有