导论;
请求乱码问题
由于现在的 request 属于接收客户端的参数,所以必然有其默认的语言编码,主要是由于在解析过程中默使用的编码方式为 ISO -8859-1(此编码不支持中文),所以解析时一定会出现乱码。要想解决这种乱码问题,需要设置 request 中的编码方式,告诉服务器以何种方式来解析数据。或者在接收到乱码数据以后,再通过相应的编码格式还原。
方式一:
request . setcharacterEncoding (" UTF -8");
这种方式只针对 POST 有效(必须在接收所有的数据之前设定)
方式二:
new String ( request . getParameter ( name ). getBytes (" ISo -8859-1")," UTF -8");
借助了 String 对象的方法,该种方式对任何请求有效,是通用的。
由于在解析过程中默认使用的编码方式为IS0-8859-1(此编码不支持中文),所以解析时一定会出现乱码。
*请求乱码问题
GET 请求
Tomcat8及以上版本不会乱码
Tomcat7会乱码,通过设置服务器解析编码的格式 new String ( request . getParameter ( name ). getBytes ("IS0-8859
post请求乱码问题:
Tomcat7及以下版本
request . setCharacterEncoding (" UTF -8”
Tomcat8会乱码,通过设置服务器解析编码的格式
request . setCharacterEncoding (" UTF -8");
乱码情况总结:
PoST 请求;无论什么版本的服务器, pos 请求中文都会乱码。(
request .setCharacterEncoding (" UTF -8");)
2.
new String ( request . getParameter (" uname "). getBytes (" ISo -8859-1")," UTF -8")
针对任何请求方式。
但是如果数据本身不乱吗,还依然使用 new String ()方法转换,则会乱码
备注:
( request .setCharacterEncoding (" UTF -8");)
只针对 POST 请求乱码有效。