tomcat怎么处理中文请求参数的-问答-阿里云开发者社区-阿里云

开发者社区> 问答> 正文

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

a123456678 2016-03-10 11:59:19 1307

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

编解码 应用服务中间件
分享到
取消 提交回答
全部回答(1)
  • a123456678
    2019-07-17 18:57:23

    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的数据进行解码。(纯手打,累死了。。。。。)

    0 0
人工智能
使用钉钉扫一扫加入圈子
+ 订阅

了解行业+人工智能最先进的技术和实践,参与行业+人工智能实践项目

推荐文章
相似问题