一、前言🔥
👨🎓作者:bug菌
💌公众号:猿圈奇妙屋
🚫特别声明:原创不易,转载请附上原文出处链接和本文声明,谢谢配合。
🙏版权声明:文章里可能部分文字或者图片来源于互联网或者百度百科,如有侵权请联系bug菌处理。
哈喽,小伙伴们,我是bug菌呀👀,不知不觉就一年又4月,正是踏青郊游的好时节。可上海疫情,除了在家远程办公就是看点技术顺便卷点文章。这不是4月又出了更文活动,逼自己一把,坚持每天做点内容输出,养成写作习惯,将来你会回来感谢曾经的自己坚持了一把才有此刻的辉煌成就。
小伙伴们在批阅文章的过程中如果觉得文章对您有一丝丝帮助,还请别吝啬您手里的赞呀,大胆的把文章点亮👍吧,您的点赞三连(收藏⭐️+关注👨🎓+留言📃)就是对bug菌我创作道路上最好的鼓励与支持😘。时光不弃🏃🏻♀️,掘金不停💕,加油☘️
二、环境说明🔥
**环境:**jdk1.8 + springboot 2.3.1 + mybatis-plus3.2 + mysql5.6
三、排错分析🔥
我coding着正快要进入忘我境界,突然我的消息一直弹屏,我还是抓紧看看具体发生了啥吧。
于是我打开vx,看到群消息后,呆住!离谱????
bug菌:"心想,不可能是我的问题的。"
小伙伴:"bug菌啊,为啥我输入的中文保存后变成一串问号了啊??我也没做字符转码呀,今天就是这个情况。你赶紧看看,肯定又是你写的bug。难怪取名叫bug菌,名副其实!。"
bug菌:"这么离谱?我啥也没变动啊,接口照旧呀,之前测了不是都正常嘛。怕不是要冤枉好人。"
bug菌:"深吸了口气,好像想到了点啥?"
bug菌:"那你再测一下别的新增接口,看看中文是不是也乱码?是只中文保存后变成了' ??? ',还是都变成' ??? '。"
小伙伴:"别的接口也是!变成了不固定的问号。"
小伙伴:"就是中文,输入的数字,字符串都不变。"
bug菌:"好的,基本了解,这是后端bug,我马上定位问题并修改bug"。
bug菌正火急火燎的赶往事故发生地。
...
小伙伴们,你们光到这儿,能精准定位问题是啥不?如果你心里没有啥解决方案,那么跟随 bug菌过来,看看他是如何一步步排查到事故现场把!
我首先打开[ idea ]编辑器,运行[ debug ]模式。
第一步:先确定,接口参数传到后端再到接口逻辑层中间是否有被转义?
排查下来并没有,且sql执行也显示中文,如下是sql执行过程:
第二步:排查一下,数据库数据保存情况,是否中午变问号了?
ok!很明显,插入的中文乱码变成了一堆问号了。
第三步:确定idea编辑器的编码格式 与数据库的编码格式否是一直?
排查下来,设置的都是utf-8 编码。
第四步:排查下来,事故是发生在sql执行上,我就想,sql执行时啥设置会对它有影响?
真相大白!大家请看:发现了什么没有?
我的数据库连接配置竟然变了!!被谁给改掉了。查看git提交记录才发现,是被我昨晚定位另一个bug临时给改了,忘了把注释放开。
到这儿,你们知道这个事故是啥了嘛?小伙伴们。
四、解决方案🔥
在你的配置文件中对配置数据库的url地址最后拼接一下如下这串,问题解决!!
&useUnicode=true&characterEncoding=utf-8
拓展:
数据库连接url拼接这串有啥作用呢?
字面解读:使用Unicode字符集并且设置字符编码为utf-8。
其实真正它的作用分两方面:
1、往数据库插入数据时:
数据库在存放项目数据的时候会先用UTF-8格式将数据解码成字节码,然后再将解码后的字节码重新使用GBK编码存放到数据库中。
2、从数据库取出数据时:
数据库会先将数据库中的数据按GBK格式解码成字节码,然后再将解码后的字节码重新按UTF-8格式编码数据,最后再将数据返回给客户端。
实际添加截图:
最后咱们重启项目,再随便通过一个新增接口试试,问题解决没有!
很明显,中文输入保存正常,接口获取时也正常,一切正常。
**完美,收工!**perfect!!
... ...
ok,以上这样就好啦,如果还想学习更多,你可以看看我的往期热文推荐哦,每天积累一个奇淫小知识,日积月累下去,你一定能成为令人敬仰的大佬的。好啦,咱们下期见~
五、往期推荐🔥
- 如何使用Mybatis-plus实现字段内容的自动填充?不会我就教你。
- 如何在swagger2中配置header请求头等参数信息?(若不会,我便手把手教你)
- Springboot系列(十六):集成easypoi实现word模板内循环导出多数据
- Springboot系列(十六):集成easypoi实现word模板图片导出
- Springboot系列(十六):集成easypoi实现excel多sheet表导入
- Springboot系列(十六):集成easypoi实现excel多sheet表导出
六、文末🔥
如果还想要学习更多,小伙伴们可关注bug菌专门为大家创建的专栏《SpringBoot零基础入门》,从无到有,从零到一!希望能帮到大家。
我是bug菌,一名想走👣出大山改变命运的程序猿。接下来的路还很长,都等待着我们去突破、去挑战。来吧,小伙伴们,我们一起加油!未来皆可期,fighting!