我们请求的中文参数会被URL转码为有%xy类型,服务器接收到这些字节数组时,遍历数组,找到name和value的字节段,解码 name和value的值并添加到map集合中,其实这就是request.getparameter的实现原理。。。不清楚的地方,在解码过程中,服务器得到的 字节数组中 带有%的字节,是怎么处理的。源码中,通过urldecode解码的这些字节,但是这个是是它自定义的,并不是URLDecode.decode
就是这里不清楚,什么时候去掉的%的字节的。
tomcat怎么处理中文请求参数的
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
2条回答 默认 最新
关注 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的数据进行解码。(纯手打,累死了。。。。。)本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥15 如何在scanpy上做差异基因和通路富集?
- ¥20 关于#硬件工程#的问题,请各位专家解答!
- ¥15 关于#matlab#的问题:期望的系统闭环传递函数为G(s)=wn^2/s^2+2¢wn+wn^2阻尼系数¢=0.707,使系统具有较小的超调量
- ¥15 FLUENT如何实现在堆积颗粒的上表面加载高斯热源
- ¥30 截图中的mathematics程序转换成matlab
- ¥15 动力学代码报错,维度不匹配
- ¥15 Power query添加列问题
- ¥50 Kubernetes&Fission&Eleasticsearch
- ¥15 報錯:Person is not mapped,如何解決?
- ¥15 c++头文件不能识别CDialog