美文网首页服务器开发安卓笔记侠Android知识
Emoji表情符号在MySQL数据库中的存储

Emoji表情符号在MySQL数据库中的存储

作者: 亦枫 | 来源:发表于2015-12-24 22:28 被阅读13128次

    在Android手机或者iPhone的各种输入法键盘中,会自带一些Emoji表情符号,如IPhone手机系统键盘包含的表情符号有:

    IPhone Emoji.png

    如果在移动端发布文本内容时包含了这种Emoji表情符号,通过接口传递到服务器端,服务器端再存入MySQL数据库:

    • 对gbk 字符集的数据库,写入数据库的数据,在回显时,变成 ‘口口’ 无法回显;

    • 对utf8 字符集的数据库,则根本无法写入数据库,程序直接报出异常信息
      java.io.exception xxxxxxxx.

    原因分析:

    Emoji表情符号为4个字节的字符,而 utf8 字符集只支持1-3个字节的字符,导致无法写入数据库。

    解决方案:

    1. 遍历输入的文本,把四字节长度的字符,修正为自定义的字符替换掉。

    2. 修改MySQL数据库字符集, 把数据库字符集从utf8 修改为支持1-4 个字节字符的utf8mb4。

    事实上可以看出,第一种方案的工作量较大,并不可取。推荐使用第二种方案,修改数据库字符集。从MySQL 5.5.3版本开始,数据库可支持4个字节的utf8mb4 字符集,一个字符最多可以有4个字节,所以能支持更多的字符集,故能存储Emoji表情符号。从 mysql 5.5.3 之后版本基本可以无缝升级到 utf8mb4 字符集。同时,utf8mb4兼容utf8字符集,utf8 字符的编码、位置、存储在utf8mb4与utf8字符集里一样的,不会对有现有数据带来损坏。

    升级方案:

    1. 修改数据库字符集character-set-server=utf8mb4 重启数据库生效。

    2. 修改database 的字符集为 utf8mb4 alter database dbname character set utf8mb4

    3. 修改表的字符集 为utf8mb4 , alter table character set = utf8mb4

    附上:

    Emoji 全编码字符集:IOS Emoji

    欢迎关注鸟哥微信公众号【技术鸟】,一起分享,共同进步!

    微信公众号【技术鸟】_二维码.gif

    相关文章

      网友评论

      • 6de098b75a36:这种方法不行的
      • 远方的枫叶:并且数据库那边的编码已经改成utf8mb4了
        亦枫:嗯,客户端不用处理
        远方的枫叶:@亦枫 我在客户端没有对系统emoji表情进行任何操作,直接post给后台了,这样没问题吗?还没重启,待会让他们重启一下
        亦枫:@远方的枫叶 重启数据库了吗
      • 远方的枫叶:我发送的系统的emoji表情,存在数据库变成问号了
      • b7999c403a4e::smile:
        亦枫:@rusty_nail :flushed:笑什么

      本文标题:Emoji表情符号在MySQL数据库中的存储

      本文链接:https://www.haomeiwen.com/subject/fvwvhttx.html