乱码出现的主要原因就是编码格式,而修改编码格式因为位置不同,也有不同的修改方式:
-
服务器端
-
服务器的不同,服务器默认的可能就是“ISO-。。。”,所以在服务器的文件目录下,打开目录:D:\apache-tomcat-8.5.4-windows-x64\apache-tomcat-8.5.4\conf
-
打开文件后修改以下代码段(红色是修改代码):
63. <Connector connectionTimeout="20000" port="8080" protocol="HTTP/1.1" redirectPort="8443" URIEncoding="UTF-8"/>
-
后台servlet端
-
设置返回字符编码格式
-
response.setCaracterEncoding()
-
-
response.setHeader("Content-type","text/html;charset=UTF-8")
-
response.setContentType("text/html;charset=UTF-8")
-
-
拦截器端
-
思路:将每次的请求都进行拦截过滤,设置req的编码格式
-
第一种方法
-
-
public void doFilter(ServletRequest req, ServletResponse resp, FilterChain arg2)
throws IOException, ServletException {
//将servletrequest转为httpservlet
HttpServletRequest request=(HttpServletRequest) req;
HttpServletResponse response=(HttpServletResponse) resp;
request.setCharacterEncoding("UTF-8");
}
-
第二种方法
-
先配置xml文件,在配置拦截器的xml文件中,配置如下
-
<filter>
<filter-name>Filter</filter-name>
<filter-class>com.qianfeng.myfiler.Filer1</filter-class>
<init-param>
<param-name>CharacterEncoding</param-name>
<param-value>UTF-8</param-value>
</init-param>
</filter>
然后在拦截器中,在init获取参数
//获取初始化参数属性的值
str=arg0.getInitParameter("CharacterEncoding");
在拦截器的dofiler中,设置:
request.setCharacterEncoding(str);
-
在前端jsp端,修改以下代码:
<%@ page language="java" contentType="text/html; charset=UTF-8"
pageEncoding="UTF-8"%>
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">