struts2中<s:url>中文自动编码问题

struts2中,如果使用<s:url>,直接放进地址栏,如果有中文的话,会发生一个自动编码。那么我们在后台如何将这已经编码的数据解码出来呢?当然,说的是中文传输。

<span style="font-size:14px;"><a href="
     <s:url value='demo.action'>  	
           <s:param name='fileName' value='fileFileName[#fn.getIndex()]'/>  
     </s:url>">点击我
</a></span>


譬如上面的这段代码,点击链接,然后发现地址栏出现了一串编码了的字符串,当然这前提是fileName这里面包含了中文。然后,我在后台进行了解码。

首先,我用的是String fn = new String(fileName.getBytes("ISO-8859-1"), "utf-8");这种方法来解码,发现解码不出来。

于是,我又用了java.net.URLDecoder.decode(fileName,"utf-8");还是解码不了。

后来我居然用String fn = new String(fileName.getBytes("ISO-8859-1"), "gbk");给搞定了。

问题来了,utf-8和gbk都是中文编码,为什么一个可以,一个又不可以了呢?我查一些资料,我个人猜测,应该这两种编码占用的字节大小的关系。ISO-8859-1属于单字节编码,最多能表示的字符范围是0-255,应用于英文系列。 很明显,ISO-8859-1编码表示的字符范围很窄,无法表示中文字符。但是,由于是单字节编码,和计算机最基础的表示单位一致,所以很多时候, 仍旧使用ISO-8859-1编码来表示。而且在很多协议上,默认使用该编码。比如,虽然"中文"两个字不存在ISO-8859-1编码,以gb2312编码为例,应该是"d6d0   cec4"两个字符,使用ISO-8859-1编码的时候则将它拆开为4个字节来表示:"d6 d0 ce c4"(事实上,在进行存储的时候,也是以字节为单位处理的)。而如果是UTF编码,则是6个字节"e4 b8 ad e6 96 87"。很明显,这种表示方法还需要以另一种编码为基础。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值