博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
微信nickname乱码(emoji)及mysql编码格式设置(utf8mb4)解决的过程
阅读量:5911 次
发布时间:2019-06-19

本文共 960 字,大约阅读时间需要 3 分钟。

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

项目中涉及保存微信的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,会造成生产系统临时当机。我认为写的比较好的方法是:,一般可参考以上方法。文章中的关键点也说的比较清楚。

下面是我的处理方法:

要求:

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数据源的配置,增加一行:
注意:此处依据不同连接池不同配置不同的参数,比如BoneCP连接池用的是 initSQL 配置
5.检查下jdbc连接串的设置: jdbc:mysql://localhost:3306/dbname?useUnicode=true&characterEncoding=utf8 这里要注意:有人建议删除useUnicode=true&characterEncoding=utf8,但好像我这里会发生保存数据时发生乱码的现象。

转载地址:http://mglpx.baihongyu.com/

你可能感兴趣的文章
laravel/lumen 单元测试
查看>>
csu2161: 漫漫上学路(Hash+最短路)
查看>>
重复引用错误:duplicate symbols for architecture x86_64
查看>>
计算机图形学 课设
查看>>
ucenter1.5通讯过程分析(转载)
查看>>
js和html5实现画板
查看>>
浏览器中可以访问,但是git命令、go get命令使用时却无法连接
查看>>
Apache Spark源码走读之7 -- Standalone部署方式分析
查看>>
如何避免重构带来的危险
查看>>
有序的双链表
查看>>
MSSQLServer的备份与还原
查看>>
Eclipse导入的项目中发现包的形式变成了文件夹的形式,需要将文件夹的形式变成包...
查看>>
使用MySQL yum源安装MySQL
查看>>
iOS8中使用CoreLocation定位
查看>>
R语言处理Time series
查看>>
mvn package时设置了maven.test.skip=true依旧执行单元测试
查看>>
Java学习笔记(一)背景知识
查看>>
PAT 1118 Birds in Forest [一般]
查看>>
Adapting to views using css or js
查看>>
020PHP基础知识——函数(三)
查看>>