1. 对get参数的处理, 可以看到
(1) org.apache.catalina.connector.Request中getParameter,
(2) org.apache.tomcat.util.http.Parameters的handleQueryParameters
最后添加参数时一句代码:
addParam( urlDecode(tmpName, enc), urlDecode(tmpValue, enc) );
所以说,进行了url解码了,但是指定的字符集enc还需要正确才能正确的处理get参数
2. 对header的处理
org.apache.coyote.http11.InternalInputBuffer的parseHeader方法
MimeHeaderField对应一个header, 先设置header的name,再设置header的value,都是原始的字节
headerValue = headers.addValue(buf, start, pos - start);
headerValue.setBytes(buf, start, realPos - start);
在读取header时
public String getHeader(String name) {
MessageBytes mh = getValue(name);
return mh != null ? mh.toString() : null;
}
所以可以看到,header若包含了中文名,则处理的返回结果应该就是乱码。