资讯专栏INFORMATION COLUMN

微信nickname乱码(emoji)及mysql编码格式设置(utf8mb4)解决的过程

xiaotianyi / 1096人阅读

摘要:自己的练习项目中涉及保存微信的,之前一直正常使用,但是突然遇到一个之前没有遇到的问题。经过调试发现错误如下经过仔细查看发现可以获得的数据,但是无法保存到数据库,查看用户的微信发现在中使用了字符。上查找发现主要解决方案就是的编码设置由转为。

自己的练习项目中涉及保存微信的nickname,之前一直正常使用,但是突然遇到一个之前没有遇到的问题。经过调试发现错误如下:

Incorrect string value: "xF0x9Fx99x88xF0x9F..." for column "nickname" at row 1
经过仔细查看发现可以获得nickname的数据,但是无法保存到mysql数据库,查看用户的微信发现在nickname中使用了emoji字符。
到百度(只能用这个,其他的麻烦呀。)上查找发现主要解决方案就是MySQL的编码设置由utf8转为utf8mb4。
具体解释可见:[详细emoji表情与utf8mb4的关系][1] ,写的非常全面详细。

网上的解决办法大多是修改my.cnf参数,设置mysql的编码为utf8mb4,这种方法虽然彻底,但是通常要重启mysql,会造成生产系统临时当机。我认为写的比较好的方法是:mysql/Java服务端对emoji的支持,一般可参考以上方法。文章中的关键点也说的比较清楚。

下面是我的处理方法:
要求:

1.MySQL的版本不能太低,低于5.5.3的版本不支持utf8mb4编码。select version();
2.JDBC驱动版本不能太低,mysql connector版本高于5.1.13。

    mysql
    mysql-connector-java
    5.1.38


3.将表中的对应字段,比如会员表的呢称字段,其字符集修改成utf8mb4。
4.最后修改druid数据源的配置,增加一行:




5.检查下jdbc连接串的设置:

jdbc:mysql://localhost:3306/dbname?useUnicode=true&characterEncoding=utf8

这里要注意:有人建议删除useUnicode=true&characterEncoding=utf8,但好像我这里会发生保存数据时发生乱码的现象。

本文重要参考:mysql : utf8mb4 的问题

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/65614.html

相关文章

  • Emoji编码常见问题处理

    摘要:题外话补充一点是一种字符编码方法,它是由国际组织设计,可以容纳全世界所有语言文字的编码方案。带有的字符串截取在这类编程语言中一个中文字符的长度为,但是对大部分的并非全部取长度则是。 我在虎嗅上看过一篇关于Emoji的趣闻, 特别有意思, 在这里跟大家分享一下。里面提到了Emoji是怎么诞生的。 1999年前后,日本一个名叫栗田穰崇的年轻人,和许多直男一样, 给女友发的短信经常会被误解。...

    wemall 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<