一次令人发疯的中文乱码

JAVA学习网 2017-08-04 21:24:01

   乱码情况描述:自己写了一个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 命令查看数据分编码方式,如果有不是继续修改

 

 

 

 

阅读(777) 评论(0)