欢迎来到[自学php网] ①群 AG亚游集团

AG亚游集团 > 网站后台 > 微信开发 >

微信nickname乱码及mysql编码格式设置(utf8mb4)

来源:自学PHP网 ?? 时间:2015-04-14 12:58?作者:

[导读] 今天在写微信公众平台项目时,写到一个用户管理模块,接口神马的已经调试好了,于是将用户从微信服务器保存到本地数据库,发现报错:java sql SQLException: Incorrect string value: xF0 x9F...

今天在写微信公众平台项目时,写到一个用户管理模块,接口神马的已经调试好了,于是将用户从微信服务器保存到本地数据库,发现报错:

 

java.sql.SQLException: Incorrect string value: '\xF0\x9F\x92\x94' for column 'nickname' at row 1

 

大致说的是保存nickname字段时,发现不正确的字符串值,于是在保存前,将用户的昵称打印了出来,发现有emoji表情,上网查了一下,utf-8大小可能有三种分别为2字节、3字节、4字节,而Mysql中的utf-8编码格式最多支持3字节,所以需要升级Mysql版本及编码格式:

 

Luckily, MySQL 5.5.3 (released in early 2010) introduced a new encoding called utf8mb4 which maps to proper UTF-8 and thus fully supports Unicode, including astral symbols.

 

也就是mysql在5.5.3版本中引入新的编码格式,取名为utf8mb4,所以如果你电脑上的版本低于此版本,请先更新电脑中的Mysql版本,查看Mysql版本:

 

mysql -V
mysql  Ver 14.14 Distrib 5.6.23, for osx10.9 (x86_64) using  EditLine wrapper

 

发现电脑中的版本没问题,于是直接找改编码格式的方法:

 

Make sure to set the client and server character set as well. I have the following in my MySQL configuration file (/etc/my.cnf):

 

于是去查找my.cnf文件所在的方位,在我电脑中路径为(用homebrew安装的)

/usr/local/Cellar/mysql/5.6.23/my.cnf

 

用sudo vim打开该文件:

$ sudo vim 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服务,查看编码格式

 

mysql> SHOW VARIABLES WHERE Variable_name LIKE 'character\_set\_%' OR Variable_name LIKE 'collation%';
+--------------------------+--------------------+
| Variable_name            | Value              |
+--------------------------+--------------------+
| character_set_client     | utf8mb4            |
| character_set_connection | utf8mb4            |
| character_set_database   | utf8mb4            |
| character_set_filesystem | binary             |
| character_set_results    | utf8mb4            |
| character_set_server     | utf8mb4            |
| character_set_system     | utf8               |
| collation_connection     | utf8mb4_unicode_ci |
| collation_database       | utf8mb4_unicode_ci |
| collation_server         | utf8mb4_unicode_ci |
+--------------------------+--------------------+
10 rows in set (0.00 sec)

 

发现已经设置成功,于是重新启动程序,发现还是报错,错误还是刚才的错误,这下可以确定问题不在数据库的编码格式中了,于是继续找答案,发现jdbc驱动有问题,当前程序中的驱动版本:

 

mysql-connector-java-5.1.7-bin.jar

 

于是去mysql官网找最新jdbc驱动,地址:

 

/devaff4mysqlaff4com/downloads/file.php?id=456317

 

版本:

 

mysql-connector-java-5.1.35-bin.jar

 

 心想这下应该可以了吧,重新启动程序,我靠! 发现还报错,继续是刚才的错误,这下只能找找hibernate配置文件中是否有问题了,hibernate配置文件中的连接地址为:

 

jdbc:mysql://wechat_development?useUnicode=true&characterEncoding=utf8 

 

上stackoverflow中找了找解决方案,里面也没说为何,直接说把后面的useUnicode及characterEncoding直接去掉就好了,于是配置文件变成如下:

 

jdbc:mysql://wechat_development 

 

 

最新文章

点击排行

自学PHP网专注网站建设学习,PHP程序学习,平面设计学习,以及操作系统学习

京ICP备14009008号@版权所有AG亚游集团

网站声明:本站所有视频,教程都由网友上传,站长收集和分享给大家学习使用,如由牵扯版权问题请联系站长邮箱904561283@qq.com

中国海军编队春节赴印度洋 至少做了5件事(图) 女子冰球世锦赛中国“复仇”韩国 球员:等了一年 法经济部长:欧洲准备采取措施抵消美制裁伊朗的影响 英国男子向百所英美学校发炸弹威胁遭警方逮捕 美巡赛球员莱尔与白血病斗争失败 目前已放弃治疗 内房普遍向下 港股午后初段倒跌44点新报31454点 代表:中国地震预警技术世界前列 应开通电视预警 论欧冠梅西真远远不如C罗 巴萨媒体也为他点赞 FIFA排名:国足第73亚洲仍第6 热身对手百名开外 库里又扣篮了!但你确定这不是吊威亚的摆拍? 俄海上阅兵“航母杀手”等40艘军舰参加 普京检阅 男子痛失爱子卧底约死群 劝自杀者珍惜生命救多人
作家阿来建议严打山寨抄袭:常看到抄袭者招摇过市 沪媒:单靠金软景上海无法夺冠 赛程安排对沪不公 北京网信、公安等部门联合约谈京东 责令全面整改 萨德尔扛反美大旗赢伊拉克大选 指控美国是大毒瘤 整容50次变僵尸版安吉丽娜-朱莉? 少女否认(图) 颁奖-齐布称之最伟大时刻 科贝尔期待明年再来 马克思故乡热情迎接“中国赠雕像”:马克思回来了 伍兹更推感谢支持:会越来越好 球迷:绿夹克是你的 爱奇艺九大货币化手段赋能全产业链多生态合作伙伴 中粮期货试错交易:5月11日市场观察 巴萨2年买人已花惊人5亿欧 是皇马的3倍多 欧元区上季GDP增速低于预期
选秀综艺太多:流量明星都不够用了 周小川:央行在研究数字货币 确保安全可靠再推广 美旅游大巴长岛撞桥被削顶 致至少37人受伤(图) 孟加拉国赛第三轮哈里森领先 刘晏玮70杆升至T28 滴滴就是否对行程录音征求意见 专家称不如安摄像 富力VS苏宁最后时刻的改判点球正确吗? 人民日报:中国理念为西方摆脱治理困境提供启示 克雷斯波盛赞米兰妖人:太成熟了 像个狡猾的老将 特朗普要求考虑对中国商品追加1千亿美元关税 最近开什么店比较好 开什么店比较有市场 手机可以做的打字兼职 在家赚钱的十种方法 AG亚游集团