SpringSide开发实战(六):AJAX,在地狱中漫步 - 编程入门网
inputs[i].value;
// 设置表单为不可用状态
inputs[i].disabled = " true " ;
}
// 提示用户正在提交数据
$( " doing " ).style.pixelTop = document.body.scrollTop + 230 ;
$( " doing " ).style.left = 250 ;
$( " doing " ).style.display = " block " ;
// 使用AJAX将数据传递到服务器,并接受服务器的回应
var ajax = new Ajax.Request(url, {method: " get " , onComplete:onResponse} );
}
乍一看来,解决这个问题似乎并不复杂,但不知大家想过没有,如果用户输入非法字符 怎么处理。在url中,有几个字符是会被引起错误的,比如"@"和"#","@"会让服务器只 把"@"后面的字符串当成有效url地址,"#"代表一个网页中的锚点。也有可能还有更多的非 法字符,我们暂时还没有发现。我曾经想过使用JavaScript的escape()来将表单中的字符编 码,但是又会引起中文无法传递到服务器。唉,看来除非在客户端使用JavaScript代码来过 滤掉这些字符,是在也想不出其它的办法。 问题二、服务器返回什么数据给AJAX对象? 我们通过AJAX把数据异步传递到服务 器,等服务器验证完毕后,服务器给我们回复什么格式的数据呢?是XML?普通文本?JSON? 还是其它。XML我首先排除,因为解析它的工作量太大了。当前,JSON最是流行。但是我更 加懒惰,我直接返回有效的JavaScript代码,这样,我在AJAX的onComplete时,只需要一行 代码,如下:
SpringSide开发实战(六):AJAX,在地狱中漫步(5)时间:2011-05-07 blogjava 海边沫沫问题三、AJAX让Validator框架走开? 在Struts中,有一个验证框架Validator,它可以很方便的完成对ActionForm的验证 。但是一旦我们使用AJAX,Validator就派不上任何用场,因为只有在jsp文件中使用Struts 的<html:form>系列标签,才能让Struts表我们的表单数据自动封装到ActionForm中 ,但是前文已经提过,我们的表单数据是通过url参数传递的,所以除非自己扩展Struts, 否则我们跟Validator无缘。 于是,所有的验证代码我们必须得在服务器端自己编写 ,即要考虑周全,又要防止出错。幸好SpringSide提供的HibernateEntityDao<T>让 我们在验证用户名和昵称是否重复时省了一大把劲。我的服务器端代码如下: // 获取用户提交的数 据并验证 // 获取用户提交的数据并验 证 public ActionForward submit(ActionMapping mapping, ActionForm form, HttpServletRequest request, HttpServletResponse response) throws Exception { boolean success = true; String result = ""; User user = new User(); // 验证用户名 String name = new String(request.getParameter ("name").getBytes( "ISO-8859-1"), "GB2312"); user.setName(name); if (name == null || name.equals("")) { success = false; result += "name_err.innerHTML=''用户名不能为空'';"; } else if (!name.matches("^[A-Za-z0-9_]*contentquot;)) { success = false; result += "name_err.innerHTML=''用户名只能包含字母、数 字和下划线'';"; } else if (name.length() > 20) { su |
凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢! |