在开发微信开放平台, 接入微信公众号的数据时, 关于用户的nickname和文本消息是,大量出现emoji的文本信息, 超时了utf-8字符集的存储范围html
在存储数据时, 出现部分特殊字符存储字符串失败. java
查阅MySQL官方文档时,给出以下支持utf8转utf8mb4的官方处理办法mysql
https://dev.mysql.com/doc/refman/5.7/en/charset-unicode-conversion.htmlsql
上述的步骤只是针对server端的配置.数据库
由于我目前的项目, 使用的是JAVA编写, 使用JDBC链接操做数据库, 以下针对的JDBC操做的解决方案微信
JDBC的URL以前的配置方式ide
String url = "jdbc:mysql://HOST:PORT/DATABASE?useUnicode=true&characterEncoding=UTF-8";
在链接配置中,声明UTF-8的字符编码,在目前的存储需求上来说,在存储emoji字符串时会报错. 就算服务端的数据库设置了utf8mb4字符集类型编码
客户端修改为以下配置url
String url = "jdbc:mysql://HOST:PORT/DATABASE?useUnicode=true&characterEncoding=utf8mb4";
客户端链接时报错,不支持该字符集code
链接配置改为
String url = "jdbc:mysql://HOST:PORT/DATABASE";
同时数据库配置文件my.cnf 进行相应的修改
[client] default-character-set = utf8mb4 [mysql] default-character-set = utf8mb4 [mysqld] character-set-client-handshake = FALSE character-set-server = utf8mb4 collation-server = utf8mb4_unicode_ci
重启服务MySQL服务
问题到此解决