tomcat怎么处理中文请求参数的

我们请求的中文参数会被URL转码为有%xy类型,服务器接收到这些字节数组时,遍历数组,找到name和value的字节段,解码 name和value的值并添加到map集合中,其实这就是request.getparameter的实现原理。。。不清楚的地方,在解码过程中,服务器得到的 字节数组中 带有%的字节,是怎么处理的。源码中,通过urldecode解码的这些字节,但是这个是是它自定义的,并不是URLDecode.decode
就是这里不清楚,什么时候去掉的%的字节的。

request这里其实在取之前,程序内l默认会自动按iso-885以9-1来解码,由于它是单字节编码,而汉字是双字节,所以会出现乱码。所以这时有request取得
参数之前,先设置解码的格式。才不会乱码。等你取得时候才会解码的。才去掉%
解析请求的URL是在org.apache.coyote.HTTP11.InternalInputBuffer的pareRequestLine方法中进行的,这个方法把传过来的byte[]设置到org.apache.coyote.Request
的相应属性。注意,这里存储的URL依然是byte格式(也就是加%),真正转换成char是发生在org.apache.catalina.connector.CoyoteAdapter的convertURI
方法中完成的。所以,有中文编码时,最好将URIEncoding设置成UTF-8编码。解码是getparameter被第一次调用时发生的。它会调用
org.apache.catalina.connector.Request中的paseParameters方法,这个方法将会对GET或POST的数据进行解码。(纯手打,累死了。。。。。)

get()方法,和post()方法 可以直接解码。UTF-8 模式