我们请求的中文参数会被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的数据进行解码。(纯手打,累死了。。。。。)
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。