转:https://blog.csdn.net/mulinsen77/article/details/87873954/
- 首先,对于mySql连接的问题:若从前端 插入中文数据,进入数据库中出现乱码,则检查数据库的编码以及在application.properties中的连接是否设置编码为UTF-8。
- 对于通过url传参,出现中文乱码的情况,需要以下几个步骤。
(1). 在application.properties中设置如下参数:
# 解决中文乱码的问题
spring.http.encoding.force=true
spring.http.encoding.charset=UTF-8
spring.http.encoding.enabled=true
server.tomcat.uri-encoding=UTF-8
(2). 在config类中,继承自WebMvcConfigurationSupport类,重写以下方法:
(有人说是:创建国际化支持配置类)
/**
* 解决中文乱码的问题
* @return
*/
@Bean
public HttpMessageConverter<String> responseBodyConverter() {
return new StringHttpMessageConverter(Charset.forName("UTF-8"));
}
@Override
public void configureMessageConverters(List<HttpMessageConverter<?>> converters) {
super.configureMessageConverters(converters);
converters.add(responseBodyConverter());
}
@Override
public void configureContentNegotiation(ContentNegotiationConfigurer configurer) {
configurer.favorPathExtension(false);
}
测试的时候,发现步骤一可以省略,但是为了保险起见,我们还是按照步骤一二来。
因为有些文章中说的是,经过步骤一之后,拦截器中回来的中文现已不乱码了,可是controller中回来的数据仍旧乱码,所以才需步骤二。
测试结果如下: