作者:树阿两 | 来源:互联网 | 2023-09-23 14:41
今天写代码有个方法返回的值是乱码这样的乱码,当时很奇怪,都设置的是utf-8.为什么是乱码.用postman看,返回的值里headers的头里有个content-Type属性里面
今天写代码有个方法返回的值是乱码
这样的乱码,当时很奇怪,都设置的是utf-8.为什么是乱码.用postman看,返回的值里headers的头里
有个content-Type属性里面的值是 text/plain;charset=ISO-8859-1
这里乱码原因就很明显了 我的utf-8的编码格式用iso-8859解码很明显就会出现乱码.
接着我就在思考为什么浏览器的会用iso编码格式去解码的.
这里返回的值是spring,我在httpservletrequest里面是没有找到contentType这个属性的,也就是说这个值不是浏览器决定的.
我将返回值改为Map 而不用spring的时候,就没有了乱码,很神奇
我当时的理解是认为可能要用spring的map转换json就会是对的,但是我决定debug看下是不是这样.
springmvc里面有这样的类
AbstractMessageConverterMethodProcessor
这个方法就是用来设置对应的编码的格式
this.getProducibleMediaTypes(servletRequest, returnValueClass);
这个方法会遍历出编译器(我以前以为只有一个就是StringHttpMessageConverter)原来有七个,这里的方法canWrite会根据你的返回类型比如String HashMap去对比哪些编译器HttpMessageConverter可以用.
String类型里面可以用的编译器有4个converter.上面的方法会排序然后选择第一个使用他的编码类型,String这个类很不幸第一就是iso.而Map对应的只有两个,都是utf-8.所以在这里map返回的值不会乱码的原因就找到了.
七个编译器合影
当然我们可以不用他的默认的编码格式而用utf-8,在spring里面配置一下就好了
这样即使返回的值用的类型是string,编码格式也是对的.在这里不得不佩服这些编写spring的人