org.apache.tomcat.util.http.Parameters processParameters 警告: Parameters: Charac

本文记录了一次在Struts2框架下处理URL参数传递时遇到的问题及解决方案。主要问题是由于使用百分号(%)转义字符导致的类型转换错误,通过调整参数传递方式从使用%(百分号)改为使用$(美元符号),最终解决了参数传递过程中的异常。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

[size=medium]异常与提示:
[/size]
2009-9-19 7:49:54 org.apache.tomcat.util.http.Parameters processParameters
警告: Parameters: Character decoding failed. Parameter skipped.
java.io.CharConversionException: isHexDigit

WARN URL:206 - Unable to put request parameters (id=%{blogPassageId}) into parameter map.
java.lang.IllegalArgumentException: URLDecoder: Illegal hex characters in escape (%) pattern - For input string: "{b"


WARN URL:206 - Unable to put request parameters (id=%{blogPassageId}) into parameter map.
java.lang.IllegalArgumentException: URLDecoder: Illegal hex characters in escape (%) pattern - For input string: "{b"


[size=medium]异常环境:[/size]

2个ACTION:

第1个:
<action name="LoadBolgPassageById-*" class="BlogPassageAction" method="loadBolgPassageById">

第2个:
<result type="redirect">LoadBolgPassageById.action?id=%{blogPassageId}</result>

第2个负责往第一个ACTION里传值,第一次写成这样:
<result type="redirect">LoadBolgPassageById.action?id=%{blogPassageId}</result>
就会出先类型转换上的错误。在ACTION里改GET属性也不行。还是报异常。


[size=medium]解决方法:[/size]

最后直接把第2个ACTION里的传值符号改了改成($):
<param name="blogPassageId">${blogPassageId}</param>
<result type="redirect">LoadBolgPassageById.action?id=${blogPassageId}</result>
注意了,blogPassageId这个属性也要加以说明哦,${blogPassageId},不然传值回退会出现逻辑BUG。

最后的问题,由于直接传了$参数,导致之后的ACTION总会跟上这个$值,如果你传成这样:

LoadBolgPassageById.action?id=1-id=${x}
之后,后面传入的${x}值总会把前面的id=1值给覆盖掉,所以后面的参数名跟之前的参数名需要不同,这样就OK了,这个破BUG。

搞定。

[size=medium]总结:[/size]

问题还是出在类型的转换上,%传入的值只存在一次,$传入的值长期存在。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值