前端发送一个get请求的过程:

仔细想一下,编码到底是用来做什么的?其实是为了节约空间,UTF-8,GBK等均采用了不同的算法来表示世界上所有的字符。
我们为什么要有这么多编码呢?因为世界上的语言太多啦,每种编码标准都或多或少的偏向某一种语言,比如GBK中的GB就是表示“国标”的意思,用它来编码汉字,比UTF-8更加节约空间。
但是用GBK来表示韩文呢?日文呢?未必有UTF-8高效,具体要根据他们的编码规则进行分析,这里只是举个例子。
而无论哪一种编码,它都要对应到最终的一个通用的字典里,这个貌似叫做Unicode字典,这个字典包含了全世界存在的所有字符,进而就得到了我们的对象。
为什么不直接传输Unicode编码?可以,但是传输起来不如编码节约空间,考虑Huffman编码。
写Java的门槛太低了,这些从业者在网上大肆发帖子,造成了良莠不齐的现象。之前在配置环境的时候为了解决win下开发spring项目的控制台乱码问题,参考了网上的一些帖子。结果稀里糊涂,把server.xml里的URIEncoding改成了UTF-8,这对于浏览器就不通用了,因为浏览器默认采用的就是ISO-8859-1进行编码。
因此,造成了乱码问题。
找到Tomcat目录下的conf目录,然后进入,打开server.xml文件,找到第一个connector标签,检查里面是否存在 URIEncoding 这个属性,如果有,把里面设置的 URIEncoding 去掉:
<Connector port="8080" protocol="HTTP/1.1"
connectionTimeout="20000"
redirectPort="8443"/>
注:由于时间仓促,本文没有深入进行校验文献,只是凭借着自己的一些基础知识理解写成,如有错误,欢迎评论区指出,谢谢!