java存储emoji表情解决方案_JAVA_编程开发_程序员俱乐部

中国优秀的程序员网站程序员频道CXYCLUB技术地图
热搜:
更多>>
 
您所在的位置: 程序员俱乐部 > 编程开发 > JAVA > java存储emoji表情解决方案

java存储emoji表情解决方案

 2018/1/4 0:36:07  huangjinjin520  程序员俱乐部  我要评论(0)
  • 摘要:1、问题产生情况在开发IM时有些有用的头像用了emoji表情或者聊天的时候用了emoji表情,然而mysql数据库用的编码是utf8_general_ci,就是utf-8编码,结果也就报错误了。emoji表情存不了在数据库。java.sql.SQLException:Incorrectstringvalue:'\xF0\x9F\x92\xAA",...'forcolumn'raw_json'atrow12、为什么会出现这种原因因为mysql的utf8编码的一个字符最多3个字节
  • 标签:解决方案 解决 Java
1、问题产生情况
    在开发IM时有些有用的头像用了emoji表情或者聊天的时候用了emoji表情,然而mysql数据库用的编码utf8_general_ci,就是utf-8编码,结果也就报错误了。emoji表情存不了在数据库。

    java.sql.SQLException: Incorrect string value: '\xF0\x9F\x92\xAA",...' for column 'raw_json' at row 1

2、为什么会出现这种原因
因为mysql的utf8编码的一个字符最多3个字节,但是一个emoji表情为4个字节,所以utf8不支持存储emoji表情。但是utf8的超集utf8mb4一个字符最多能有4字节,所以能支持emoji表情的存储。

3、解决方案

    方案一:修改数据库的编码集设置为utf8mb4,无论是数据库还是表,还是字段。虽然会增加存储,但是这个可以忽略不计。

   方案二: 有时候原因不能修改数据库编码之类的,可以用java对emoji表情进行转化编码,例如emoji-java这种对emoji表情进行特殊处理的jar哦,然后保存或者去掉表情,这也是一种折中的解决方案。

  emoji-java的下载地址: https://github.com/vdurmont/emoji-java

关注我是我最大的动力


  • class='magplus' title='点击查看原始大小图片' />
  • 大小: 39.9 KB
  • 查看图片附件
上一篇: 明年发布的JDK10,程序员们怎么看呢? 下一篇: 没有下一篇了!
发表评论
用户名: 匿名