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

本身的练习项目中涉及保存微信的nickname,以前一直正常使用,可是忽然遇到一个以前没有遇到的问题。通过调试发现错误以下:

Incorrect string value: '\xF0\x9F\x99\x88\xF0\x9F...' for column 'nickname' at row 1
通过仔细查看发现能够得到nickname的数据,可是没法保存到mysql数据库,查看用户的微信发如今nickname中使用了emoji字符。
到百度(只能用这个,其余的麻烦呀。)上查找发现主要解决方案就是MySQL的编码设置由utf8转为utf8mb4。
具体解释可见:[详细emoji表情与utf8mb4的关系][1] ,写的很是全面详细。

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

下面是个人处理方法:
要求:java

1.MySQL的版本不能过低,低于5.5.3的版本不支持utf8mb4编码。select version();
2.JDBC驱动版本不能过低,mysql connector版本高于5.1.13。
<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
    <version>5.1.38</version>
</dependency>

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


<property name="connectionInitSqls" value="set names utf8mb4;"/>

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

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

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

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

相关文章
相关标签/搜索