关于 服务器获取浏览器中文参数编码 问题的思考

浏览器Post方式发送,可以设置struts.i18n.encoding属性为UTF-8,这样Struts会在request.getParameter前自动执行request.setCharacterEncoding ("UTF-8"),以及返回视图前自动执行response.setCharacterEncoding ("UTF-8")。 这样服务端就不会获取到乱码。这个属性设置,对于Get请求无效,Get方式的参数不在消息体中,在头部,这部分由Web容器来解析,默认Web容器以ISO-8859-1来编码,该编码不支持中文。对于Get请求参数,有两种方法

  1. 可以先按ISO-8859-1来解码获得字节数组,再按其发送格式编码。发送格式和浏览器客户端有关,中文浏览器默认为GBK。
    通过Ajax方式发送get请求,在发送之前先使用encodeURI编码(UTF-8),然后服务端先按ISO-8859-1来解码,再UTF-8格式编码即可获取到中文。即new String(request.getParameter(String).getBytes("ISO-8859-1"),"UTF-8")。
  2. 或者对中文两次使用encodeURI编码,服务端使用java.net.URLDecoder.decode(request.getParameter(String),"UTF-8") 来一次解码即可。
    因为 Java 中的 request.getParameter(String) 方法会进行一次 URI 的解码过程,调用时内置的解码过程会导致乱码出现。而 URI 编码两次后, request.getParameter(String) 函数得到的是原信息 URI 编码一次的内容。接着用 java.net.URLDecoder.decode(String str,"UTF-8") 方法,将已经编码的 URI 转换成原文。

    考虑到对客户端浏览器复杂性的兼容,避免服务硬性的写死编码,建议第二种方法,不过最好的方法还是写一个过滤器,统一进行转码,这样符合设计规范和后期维护。 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值