乱码情况描述:自己写了一个App的后台,项目架构架构Stringmvc+mybatis,开发完成的系统在本地Tomcat服务中显示是正常的,但是部署到阿里服务器上之后,从数据中读取的数据只要带有中文的都是乱码。最讨厌的就是本地正常,但是部署到服务器上出问题的情况了,调试不方便。最后解决问题花费了不少时间,在此记录一下。
所谓中文乱码的出现的主要是因为客户端 ,服务器 以及数据库三者之间使用的编码的方式不一样,一般情况下,只要三者使用的编码方式是一样的,就不会出现乱码。
1.在代码之中使用编码过滤主要是配置在web.xml中
<!-- 编码过滤器 -->
<filter>
<filter-name>encodingFilter</filter-name>
<filter-class>org.springframework.web.filter.CharacterEncodingFilter</filter-class>
<async-supported>true</async-supported>
<init-param>
<param-name>encoding</param-name>
<param-value>UTF-8</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>encodingFilter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
2.修改服务器 Tomcat的配置文件 :在Tomcat根目录下的conf下面的 server.xml 找到下面 添加上 URIEncoding="UTF-8"
<Connector port="8080" protocol="HTTP/1.1"
connectionTimeout="20000"
redirectPort="8443" URIEncoding="UTF-8"/>
3.修改mysql数据库编码方式
登入mysql数据库之后,使用show variables like "char%" 查看mysql数据库的编码情况 并且使用命令依次修改
set character_set_client=utf-8 ;
使用alter database 数据库名 CHARACTER SET utf8; 设置自己所创建的数据库的编码方式
使用 status 命令查看数据分编码方式,如果有不是继续修改