今天在做web项目时,发现在插入数据库时出现了中文的乱码问题,在网上找了一大堆,无非就是一个问题,那就是数据库的编码设置有问题,在这里仅仅只是讲一下方法是怎么做的:
1.在MySQL中使用show Variables like 'char%'命令查看MySQL的编码格式,如果不是utf-8格式就全部都换成utf-8格式的,反正换成这个没啥错,具体等之后在深究;
2.直接了当在MySQL的安装目录下编辑my.ini文件
[client]
default-character-set=utf8
[mysql]
default-character-set=utf8
[mysqld]
default-character-set=utf8
有的就更改,没有就填上
之后,在写数据库的时候在CREATE DATABASE database_name default character set utf8 collate utf8_general_ci;加上这个
最后用show Variables like 'char%'得出这样:
就可以了。
3.这样MySQL就基本不抽风了,不过,我后来发现自己在前端jsp页面传入Controller的时候数据也出现了乱码,所以导致插入数据库的时候也是乱码形式,解决方法很简单,就是添加一个编码过滤器就行了
<filter>
<filter-name>Spring character encoding filter</filter-name>
<filter-class>
org.springframework.web.filter.CharacterEncodingFilter
</filter-class>
<init-param>
<param-name>encoding</param-name>
<param-value>utf-8</param-value>
</init-param>
</filter>
<filter-mapping>
<filter-name>Spring character encoding filter</filter-name>
<url-pattern>/*</url-pattern>
</filter-mapping>
这样就全部解决了!!!
不得不说,这个编码的问题我一直很少涉及,也没有深究过,这次暴露出了很多问题,不过我只是有了解决方法,但是并不清楚原理,往后弄懂了原理再回来填坑。