欢迎来到[自学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

嘴仗到底谁赢了?吵架能帮穆里尼奥和孔蒂赢球吗 利物浦名宿遭停职+谴责 朝曼联球迷吐口水惹祸 亚汇中国:美联储送出鹰派立场 美元春天来临 林黛玉到底长什么样? 空姐夜乘滴滴被害 其父:闺女被发现时身上有精斑 外媒:韩国称中国军机在韩“防识区”飞行超4小时 沪媒分析败因:首胜留下后遗症 内外线都没手感 巴萨冷平造1赔6.7冷门 周中足彩头奖20注48万 华裔男子宣布竞选美国总统 想给美国人“开支票” 台湾花莲县海域发生4.4级地震 震源深度6千米 鲁媒:广厦诠释团队篮球 山东输球原因看三数据 EIA原油库存超预期大降615万桶 美油短线拉升近1美…
动物界这么多同性恋 是雌雄比例悬殊导致的吗? 贵州省委书记:来一场振兴农村经济的深刻产业革命 媒体:香港不缺少土地 缺的是向自己动刀子的能力 韩国官方发声:敦促朝鲜尽快参加朝韩高级别会谈 台媒警示蔡英文:大陆会观察两岸论述 别踩底线 国安最猛火力枪口热的发烫 要破纪录之时却遇尴尬 教育部:超级中学提前招生有历史原因 需研究规范 黑龙江主帅透露扳平原因 身为新军目标就是保级 造车新势力闯关:巨额融资也无法化解的难题 近30%美国人考虑买中国产汽车:主因是低价 英媒:中美大使世贸交锋火药味浓 4日迎学生返程客流高峰 广铁发送旅客156万人次
一天募集10亿,太空链涉嫌欺诈全调查 张宝艳:志愿者没有一分钱的报酬 每天在无私付出 环球时报社评:中美下周贸易磋商将是高难度的 苏缘杰:比赛踢得少没给自己压力 我们外援是最好的 哈登26分保罗两双 火箭背靠背胜雄鹿获17连胜 高盛警示美股深度回调风险 特朗普5月前与金正恩见面 将谈永久弃核议题 伊布参加世界杯?国家队主帅:这事我说了算! “五险一金”迎来4个大变化 对你有啥影响? 亩收益10万的种植品种 谁需要钱我借他100万 养20头牛一年赚多少钱 不怕死想发财的兄弟进 AG亚游集团