开发者社区> 问答> 正文

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

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

展开
收起
a123456678 2016-03-10 11:59:19 2959 0
1 条回答
写回答
取消 提交回答
  • 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的数据进行解码。(纯手打,累死了。。。。。)

    2019-07-17 18:57:23
    赞同 展开评论 打赏
问答排行榜
最热
最新

相关电子书

更多
Apache Tomcat 的云原生演进 立即下载
低代码开发师(初级)实战教程 立即下载
阿里巴巴DevOps 最佳实践手册 立即下载