Jquery+Ajax+struts2+乱码问题

本文介绍了一种解决Struts2与JQuery AJAX交互时中文乱码的方法。通过调整Struts2配置及修改AJAX数据传递方式,确保中文数据正确传输与解析。

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

当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");正常显示!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值