首先,感谢我昨天的提问http://www.iteye.com/problems/27665有那么多热心的同志回答!是他们提供的资料帮我解决了这个问题。一下开始我的正文:
昨天要做一个查询分页,因为以前没有做过中文的查询,这次确实费了一番功夫才解决,一下记录整个过程希望能帮助和我遇到同样问题的朋友们。
我的需求是如下图所示的一个酒店搜索:
项目中使用的是Spring的org.springframework.web.filter.CharacterEncodingFilter做的字符过滤器,页面和数据库都使用的是utf-8的编码,tomcat默认编码是iso-8859-1没有改动。
第一步:当这个查询的表单提交的时候Action 中第一次查询,JSP页面显示数据列表和分页,一切正常,分页的按钮链接中包含了查询条件,当然包含了汉字。但是点下一页的时候Action中读到的参数就是乱码了。这是大家都能做到的一步,往下可能很多入门者就会搞乱了。
第二步:
大家都知道Tomcat默认是不支持汉字uri的,所以我们要把传到页面的uri进行处理,网上很多介绍的,就是使用JS来处理,这里涉及到JS三个方法的escape、encodeURI、encodeURIComponent,务必理解这三个方法,这个地方有介绍:http://blog.csdn.net/sfdev/archive/2009/01/20/3842857.aspx,我用到的是encodeURI。
我处理分页链接中的汉字方法如下:
1.把分页的页面、上下页这些链接包含在一个div中
<div id="pageDivShow">
<jsp:include page="/manage/util/pagination.jsp"><%--一些参数传递--%></jsp:include>
</div>
2.使用Js修改这个div中的uri,我使用的是Jquery来做的,代码如下:
$(document).ready(function(){ $("#pageDivShow a").each( function(){ var h=$(this).attr("href"); $(this).attr({href:encodeURI(h)}); } ); });
到此页面部分工作告一段落,我看资料里介绍JS的encodeURI方法是默认转换为utf-8,它也没有传入编码的方法。
第三步:
在Action中获取第一次Form提交的数据时可以直接获得正确的汉字,但是从分页上提交到Action中的数据要做另外一步的处理:
new String(value.getBytes("iso-8859-1"),"utf-8");
通过这个方法就可以正确的获得分页传回的汉字参数了。
这里就又产生了一个新的问题,就是我们要区分提交给Action的请求来源是Form提交的,还是分页中提交的,这样就简单了,用一个变量就可以解决。
到此结束,很简单吧,如果还不能理解就照着做个demo,有问题欢迎交流!
再次感谢昨天热心回答我提问的同志们!