这个异常的发生是由于字符的转换造成的,如果你遇到了这个问题,
请先检查一下你的jsp页面里面参数传递中是否有参数包含有“%”
字符,如果有必须做如下转换:
-----------------请求方------------------------
client.jsp
<script>
function doQuery(){
var sql = "select * from T_TESTTABLE where USERNAME like '王%'";//含有"%"的字符串
var url = "server.jsp?sql="+sql;
url = encodeURI(url); //如果不对url进行重新编码,就会抛出标题的异常
url = encodeURI(url); //别问我为什么要两次,因为我也不知道
window.open(url,800,600);
}
</script>
----------------服务方------------------------
server.jsp
<@ page contentType="text/html; charset=GBK">
<%
String sql = request.getParameter("sql");
sql = java.net.URLDecoder.decode(sql,"UTF-8"); //对编码后的字符进行解码得到原来的字符串
%>
以上为自己实际开发中遇到的问题和解决方案,如有不对的情大家帮忙指正!
激情与创新 尽在Blue Kiss