当遇到校验数据库中是否存在已有记录这种需求时,需要先用AJAX提交后台ACTION 判断是否数据库中存在记录,通过返回JSON型数据,在前台接收,输出结果: 比如拿登录用户举例: <% String path = request.getContextPath(); String basePath = request.getScheme()+"://"+request.getServerName()+":"+request.getServerPort()+path+"/"; %> 首先定义好全局路径 form表单中的登录按钮type="button" 手动进行提交, 加上onclick事件 onclick="login.submit();" 在用户名框附近可以写上错误块,定义一个message属性来传递错误信息: <div id="errmsg" class="errorBox" style='display:none;'> <span id="err_id"></span><s:property value="getText(message)" escape="false" /> </div> (表单中是不需要写action和onsubmit()的) 关联login和login_Func var login = new login_Func(); 在JS中定义好loginFunc这个方法 var login_Func=function() { } login_Func.prototype.submit=function() { 此处可以加上用户名 密码是否为空的校验如 var usernameVar = document.getElementById('username').value;或 =$('#username').val(); 可以参照: if( $('#username').val() == '' ) { $('#errmsg').css({'display':''}); $('#err_id').html('<s:property value="getText('login.userName.null')" />'); return false; } else if($('#password').val() == '' ) { $('#errmsg').css({'display':''}); $('#err_id').html('<s:property value="getText('login.passWord.null')" />'); return false; } 假设JSON出参有两个KEY 那么就先设两个变量来接这两个KEY,一个成功,一个失败 var submitFlag = null; var errorFlag = null; 需要把界面的用户名和密码封装成JSON参数,采用POST方式传递值 var userParam = { "user.username":$("#username").val(), "user.password":$("#password").val() };其中user.username表示后台可以通过user.getUsername()的方式来获取其值,如果参数为username的话,则后台的user则为null.... 如果想alert userParam的数据方法,可以看上一篇文章 。 定义ajax $.ajax ( { url:'validate.shtml',//先走校验的action cache:false, //拒绝缓存 async:false, //异步提交 type:'post', data:userParam, dataType:'json', success:function(data) { submitFlag = data.SUBMIT_FLAG;//如果采用此种方式获得后台的SUBMIT_FLAG, GOOGLE浏览器没问题, 火狐没问题,IE6是有问题的,他不认的SUBMIT_FLAG是什么 errorMessage = data.ERROR_MESSAGE; //所以采用下面的方法获得json数据 //retdata存储value //pro存储key var retdata = eval("("+data+")"); for (var pro in retdata) { if(pro=="SUBMIT_FLAG") { alert(retdata[pro]); } else if(pro=="FAILURE_FLAG") { alert(retdata[pro]); return; } /* if(retdata[pro]=="SUBMIT_FLAG") { alert("保存成功!"); } else if(retdata[pro]=="FAILURE_FLAG") { alert("角色名已存在!"); }*/ } //或者用这种方式 显示更友好 if(pro=="SUBMIT_FLAG") { 提交操作,见下 } else if(失败的key) { $('#errmsg').css({'display':''}); $("#err_id").html(""); if(pro==失败的key) { $("#err_id").append("用户不存在"); } else if(pro==失败的key) { $("#err_id").append("密码错误"); } } } } ); if ('undefined' != submitFlag && null != submitFlag && 'true' == submitFlag) { document.getElementById("loginForm").action='<%=basePath%>'+"login.shtml";//成功则提交login document.getElementById("loginForm").submit(); } else { } } 后台: HttpServletResponse response = ServletActionContext.getResponse(); response.setContentType("text/html;charset=utf-8"); response.setHeader("Pragma","No-cache"); response.setHeader("Cache-Control","no-cache"); response.setHeader("Cache-Control", "no-store"); PrintWriter writer = response.getWriter(); JSONObject json = new JSONObject(); 校验操作 成功 json.put("SUBMIT_FLAG","保存成功!"); 失败 json.put("FAILURE_FLAG", "用户名已存在!"); writer.write(json.toString()); writer.flush(); writer.close(); struts2中 返回json类型: <result type="json">
详细解决方案
初学AJAX异步交付获取JSON类型数据
热度:208 发布时间:2012-11-25 11:44:31.0
相关解决方案
- (Struts2+JSON+Ajax) XMLHttpRequest ==500如何解决
- 。各位大神,小弟有个简单的有关问题,就是小弟我用struts+ajax+juery+json时为何总是不进入action啊 配置文件如上
- json 解析有关问题
- ajax 多值 jsp 急
- struts2-json中诠注@JSON(deserialize=false)是什么用?不是阻止JSON反序列化成JAVA对象吗?求解
- ajax responsetext 替空值,想不通。
- springmvc jquery ajax 提交复杂对象,415异常解决办法
- jquery ajax select解决方法
- 请教哪里可以上到 struts2-json-plugin-2.1.8的源文件
- Ajax 更新商品列表下一页,页面不在脑袋开始
- CAPTCHA 模块中 ajax form 导致CAPTCHA session reuse attack detected异常,解决方法
- ajax Post 一直返回的是error ,为啥
- struts2 ajax 上拉框联动有关问题
- AJAX 学习过程中的有关问题
- java+jquery easy ui + json + struts分页例子
- servlet+jquery1.4.2(ajax error?)解决方案
- jQuery.ajax()请求struts2数据 回到data值了undefined
- ssh json jar 有关问题
- 扭结,AJAX WEB UI库选型
- 求大神解决偏题 - jquery ajax
- json 有关问题
- AJAX 传递数据如何样才可以是 json
- jquery.load(*json) 解析不已。求帮忙
- ajax 调用很慢解决办法
- ajax 拓扑图 实现,该如何解决
- struts2+jquery+ajax 回调函数没反应啊请们帮忙看看啊 跪谢
- ajax 怎么实现文件下载
- 使用$.ajax()异步无刷新请求servlet无反应解决方法
- struts2+ajax+oracle实现目录树,该怎么解决
- jquery- ui ajax 下拉列表框解决思路