乱码问题和解决方法
一、界面到控制器乱码
-
界面提交的数据默认的使用ISO-8859-1的编码,该编码不支持中文,因此乱码,乱码表现为?????
-
解决方案:在web.xml中设置编码过滤器,spring框架提供了编码过滤器类。
<!-- 编码过滤器 -->
<filter>
<filter-name>character</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>character</filter-name>
<url-pattern>*</url-pattern>
</filter-mapping>
二、入库后乱码
- 界面到控制器没有乱码,控制器到业务没有乱码,业务到dao没有乱码,dao到数据库乱码了。
- 原因1:数据库的编码不支持中文
- 数据库在安装时没有更改默认编码,导致数据库默认编码是拉丁编码,如下图所示
- 解决办法:在创建数据库脚本时设置编码,如下
CREATE DATABASE IF NOT EXISTS `luasedu1` DEFAULT CHARACTER SET utf8;
USE `luasedu`;
CREATE TABLE `score` (
`id` INT(11) NOT NULL AUTO_INCREMENT,
`stuName` VARCHAR(20) DEFAULT NULL,
`gender` CHAR(1) DEFAULT NULL,
`courseName` VARCHAR(50) DEFAULT NULL,
`courseScore` INT(11) DEFAULT NULL,
PRIMARY KEY (`id`)
) ENGINE=INNODB AUTO_INCREMENT=3 DEFAULT CHARSET=utf8;
- 原因2:连接字符串没有设置编码
- 连接字符串没有设置编码,例如
连接字符串没有设置编码,例如
jdbc\:mysql\://localhost\:3306/luasedu
解决办法
jdbc\:mysql\://localhost\:3306/luasedu?characterEncoding=utf8