request.setCharacterEncoding():这个方法只是通知Tomcat按何种编码解码用户请求后交给对应Servlet处理,不会改变底层的二进制!另外,这个方法只对没有处理的POST请求有效,如果我们不调用该函数,Tomcat会用默认编码解码。
GET请求是由web服务器处理的(web服务器运用默认编码解码该请求),不会交给对应的Servlet处理,所以该函数无效,
Tomcat配置默认编码:
配置文件为server.xml
<Server port="8105" shutdown="SHUTDOWN">
...
<Service name="Catalina">
<Connector port="8180" URIEncoding="UTF-8" />//主要配置URIEncoding
<Engine name="Catalina" defaultHost="localhost">
<Host name="localhost" appBase="webapps" />
</Engine>
</Service>
</Server>
若在调用该函数前,我们已经调用过getparameterXXX()处理POST请求,则该POST请求相当于被处理过,此时该函数也无效。
request中的setCharacterEncoding方法作用是用指定的编码集去覆盖request对象中的默认的"ISO-8859-1"编码集,这样request.getParameter("")方法就会用新的编码集去解码,但是这个方法有一个条件,就是必须在第一次使用request时就要调用这个方法来设置编码集,否则该方法就会无效。
错误示例:
<%
if(request.getParameter("function").equals("validation")){
request.setCharacterEncoding("utf-8");
userName = request.getParameter("userName");
}
%>
<%= userName%>
若userName是获取中文的话,<%=userName%>输出的依然是乱码,即request的setCharacterEncoding方法没有起到作用。因为request在if的判断条件中就被使用了,后面的setCharacterEncoding方法都会失效。正确的方法应该如下:
正确示例:
<%
request.setCharacterEncoding("utf-8");
if(request.getParameter("function").equals("validation")){
userName = request.getParameter("userName");
}
%>
<%= userName%>
这样userName获取中文就不会是乱码了