RestTemplete的Http消息解码 ,依据HttpMessageConverter的 supportedMediaTypes的匹配 Response中的 (MessageBodyClientHttpResponseWrapper( response ) )的 contentType 值。
在不指定messageConvert时,依据(但匹配的顺序依据如图的顺序)RestTemplete的Http构造的HttpMessageConverters的顺序匹配,且未指定parameter (例如application/json; charset = utf-8)的情况下 ,则由ios8859-1字符集 messageConvert( */* 匹配所有类型)解码。
所以避免问题常用
- 在ContentType :vapplication/json; charset = utf-8;
- 或者指定消息转换器,指定字符集
- 不建议采用RestTemplete用在生产代码,如用需做好如上的考察。


如测试时,可以在本地代码设置 MessageConverter // 设置restemplate编码为utf-8 restTemplate.getMessageConverters().set(1,new StringHttpMessageConverter(StandardCharsets.UTF_8));
RestTemplate的智能Http解码策略:字符集匹配与推荐实践
本文探讨了如何在RestTemplate中根据Response的Content-Type自动选择合适的HttpMessageConverter进行解码,重点关注默认情况下字符集匹配和指定消息转换器的重要性。同时,提到了在生产环境中避免字符集问题的建议和测试时的配置技巧。





