问题分析:
1、JSP页面中编码问题
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
2、Servlet接收JSP页面传值的处理(此处以接收传输过来的name参数举例)
String name = new String(request.getParameter("name").getBytes("ISO-8859-1"),"UTF-8");
3、项目web.xml文件配置(不是很重要,一般来说不是这里的问题)
<web-app>
<filter>
<filter-name>setCharacterEncodingFilter</filter-name>
<filter-class>org.apache.catalina.filters.SetCharacterEncodingFilter</filter-class>
<init-param>
<param-name>encoding</param-name>
<param-value>UTF-8</param-value>
</init-param>
<!-- <async-supported>true</async-supported> -->
</filter>
</web-app>
4、Tomcat配置问题(位置: apache-tomcat/conf/server.xml 这两段代码原先就有,需要在上面加上URIEncoding="UTF-8")
<Connector port="8080" protocol="HTTP/1.1" connectionTimeout="20000" redirectPort="8443" URIEncoding="UTF-8" />
<Connector port="8009" protocol="AJP/1.3" redirectPort="8443" URIEncoding="UTF-8"/>
5、mysql配置问题(这里只提供有关于CentOS 7上面MariaDB的有关修改方法)
首先检查编码方式
mysql> show variables like 'char%';
要将其中value为latin1的修改为utf8,则需要进入/etc/my.cnf.d/文件夹,修改client.cnf和server.cnf
vi /etc/my.cnf.d/client.cnf
在[client]下面添加
default-character-set=utf8
vi /etc/my.cnf.d/server.cnf
在[mysqld]下面添加
default-character-set=utf8
重启MariaDB,即可进行测试。
systemctl restart mariadb