ajax提交struts乱码,Jquery+Ajax+struts2+乱码问题

当Jquery和struts2同时使用时一个巧妙解决乱码的问题,

struts2有自带一个Encoding的Filter能解决乱码问题,当然有中文的时候,form要用post请求。具体配置如下:

这个要struts2 的2.1.8版本才能使用,但是2.1.6也可以使用,但是在web.xml中就要用一下配置才可以

struts2

org.apache.struts2.dispatcher.FilterDispatcher

这个filter-class是官网上不提倡用的。如果struts2的版本是2.1.8的话当然就可以使用官网上推荐用的filter了

struts2

org.apache.struts2.dispatcher.ng.filter.StrutsPrepareAndExecuteFilter

配置了以上都可以解决掉所有带中文的post提交,不会出现乱码。但是如果和ajax一起使用起来:

var url_2 = "/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 = "/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");正常显示!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
好的,实现用户注册需要前端页面和后台接口,以下是一个简单的示例代码。 前端页面: ```html <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>用户注册</title> <script src="https://cdn.bootcdn.net/ajax/libs/jquery/3.6.0/jquery.min.js"></script> <script> $(function () { $("#register-btn").click(function () { var username = $("#username").val(); var password = $("#password").val(); var data = { "username": username, "password": password }; $.ajax({ type: "POST", url: "register.php", data: data, dataType: "json", success: function (result) { if (result.code == 0) { alert("注册成功!"); window.location.href = "login.html"; } else { alert(result.msg); } }, error: function () { alert("请求失败!"); } }); }); }); </script> </head> <body> <div> <label>用户名:</label> <input type="text" id="username" name="username" placeholder="请输入用户名"> </div> <div> <label>密码:</label> <input type="password" id="password" name="password" placeholder="请输入密码"> </div> <button id="register-btn">注册</button> </body> </html> ``` 后台接口(register.php): ```php <?php header('Content-Type: application/json; charset=utf-8'); $code = 1; $msg = "注册失败!"; if ($_SERVER["REQUEST_METHOD"] == "POST") { $username = $_POST["username"]; $password = $_POST["password"]; // 注册逻辑 // ... $code = 0; $msg = "注册成功!"; } $result = array( "code" => $code, "msg" => $msg ); echo json_encode($result); ?> ``` 说明: 1. 前端页面使用 jQuery 发送 POST 请求到后台接口,data 参数是一个 JSON 对象,包含用户名和密码。 2. 后台接口接收到 POST 请求后,获取用户名和密码,然后执行注册逻辑,这里只是一个简单的示例,实际开发中应该根据业务需求进行完善。 3. 注册成功后,后台接口返回 JSON 数据,包含 code 和 msg 两个字段,前端页面根据返回的 code 判断注册是否成功,如果成功则跳转到登录页面,否则弹出错误提示。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值