zoukankan      html  css  js  c++  java
  • 微信nickname乱码(emoji)及mysql编码格式设置(utf8mb4)解决的过程

    转:https://segmentfault.com/a/1190000004594385

    项目中涉及保存微信的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。
    <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;"/>
    注意:此处依据不同连接池不同配置不同的参数,比如BoneCP连接池用的是 initSQL 配置
    5.检查下jdbc连接串的设置:
    
    jdbc:mysql://localhost:3306/dbname?useUnicode=true&characterEncoding=utf8
    
    这里要注意:有人建议删除useUnicode=true&characterEncoding=utf8,但好像我这里会发生保存数据时发生乱码的现象。
  • 相关阅读:
    UVA 1152 4 Values whose Sum is 0
    IOI 2006 Pyramid
    CTSC 2000 冰原探险
    IOI 2009 Mecho
    IOI 2011 Rice Hub 米仓
    NOIP 2013 火柴排队 程序
    USACO 2004 MooFest 奶牛集会
    USACO Training Section 3.1 Contact
    动态加载Ribbon功能区
    Ribbon2: 创建动态的Ribbon库
  • 原文地址:https://www.cnblogs.com/tv151579/p/10176820.html
Copyright © 2011-2022 走看看