日期:2014-05-16 浏览次数:20789 次
当Jquery和struts2同时使用时一个巧妙解决乱码的问题,
struts2有自带一个Encoding的Filter能解决乱码问题,当然有中文的时候,form要用post请求。具体配置如下:
<constant name="struts.i18n.encoding" value="UTF-8" />
这个要struts2 的2.1.8版本才能使用,但是2.1.6也可以使用,但是在web.xml中就要用一下配置才可以
<filter-name>struts2</filter-name>
??<filter-class>org.apache.struts2.dispatcher.FilterDispatcher</filter-class>
这个filter-class是官网上不提倡用的。如果struts2的版本是2.1.8的话当然就可以使用官网上推荐用的filter了
<filter-name>struts2</filter-name>
?<filter-class>org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter</filter-class>
?
配置了以上都可以解决掉所有带中文的post提交,不会出现乱码。但是如果和ajax一起使用起来:
var url_2 = "<%=path%>/school_class/classGradeAction_validatorName.action?formMap.gradeName="+$("#gradeName").val()+"&formMap.gradeId="+$("#id").val();
??$.ajax({
???? type: "POST",
???? url: url_2,
???? async : false,
???? data: null,
???? success: function(treeHtml){
?????? msg = treeHtml;
???? }
??});
formMap是struts的Action里的一个map对象,这样就会出现乱码问题了。改用以下方式乱码问题解决:
var url_2 = "<%=path%>/school_class/classGradeAction_validatorName.action"
??var data_2 = {'formMap.gradeName':$("#gradeName").val(),'formMap.gradeId':$("#id").val()};
??$.ajax({
???? type: "POST",
???? url: url_2,
???? async : false,
???? data: data_2,
???? success: function(treeHtml){
?????? msg = treeHtml;
???? }
??});
后台通过String gradeName =this.formMap.get("gradeName");正常显示!